js -- ES6(二)-- let 和 const 命令(根据阮一峰ES6标准入门整理)

本文详细探讨了ES6中的let和const命令,包括它们的基本用法、块级作用域、暂时性死区以及常量的不变性。let避免了变量提升,存在TDZ,不允许重复声明。const声明的变量值不可变,但对象引用仍可修改。同时,介绍了跨模块常量的声明方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目前正在学习ES6,根据阮一峰的ES6入门2,学到哪更新到哪里,都是基本的知识,复杂的目前还不会,涉及的代码都是亲自运行过的,若发现错误请指正。

ES6声明变量的方法:var、function、let、const、import、class

二、let 和 const 命令

1、let 命令

基本用法

let 命令用于声明变量,类似于var,但是所声明的变量只在let命令所在的代码块内有效。

不存在变量提升

let不像var那样会发生变量提升的现象,所以,变量一定要声明后使用,否则报错

console.log(a);//a is not defined
let a = 2;
暂时性死区(temporal dead zone 简称:TDZ)

在代码块内,如果存在let 或 const 命令,它所声明的变量就绑定这个区域,不再受外部的影响,只要在声明之前就使用这些变量,就会报错。

比较隐蔽的“死区”
function bar(x=y,y=2) {
    console.log(x);
    console.log(y);
}
bar(); //y is not defined

报错的原因是,参数 x 的默认值等于 y,而此时 y 还没有声明,属于“死区”

function bar(x=2,y=x) {
    console.log(x);
    console.log(y);
}
bar();//2、2
不允许重复声明

let 不允许在相同作用域内重复声明同一个变量

function bar(a) {    
  let a;  
}
bar();//Identifier 'a' has already been declared
function bar(a) {
   {
     let a;
   }
}
bar();//不报错

2、块级作用域

外层作用域无法读取内层作用域的变量,同理,块级作用域外部无法调用块级作用域内部定义的函数

{
  let a = '111';
  function f(){
    console.log(a);
  }
};
f();//f is not defined

如果需要调用,则要像下面这样处理

let f;
{
  let a = '111';
  f = function (){
    console.log(a);
  }
}
f();

注意:在严格模式下,函数只能在顶层作用域和函数内声明,其他情况(比如if代码块、循环代码块)下的声明都会报错

3、const 命令

const 用来声明常量,一旦声明,其值就不能改变。const 一旦声明,就必须立即初始化,不能留到以后赋值

const a;
a = 1;
console.log(a); //Missing initializer in const declaration

const 命令声明的变量也不能提升,同样存在暂时性死区,只能在声明后使用。

对于引用类型的变量,变量名不指向数据,而是指向数据所在的地址。const 命令只是保证变量名指向的地址不变,并不保证改地址的数据不变

const foo = {};
foo.name = 'bocai';
console.log(foo.name);//baocai

foo = {};//Assignment to constant variable.

上面的代码中,常量foo储存的是一个地址,指向一个对象。不可变的只是这个地址,即不能把foo指向另一个地址,但对象本身是可变的,依然可以为其添加新属性。

如果想将对象冻结,应该使用Object.freeze方法。

const foo = Object.freeze({});
foo.name = 'bocai';//不起作用
console.log(foo.name);//undefined

4、跨模块常量

let 声明的变量 和 const 声明的常量只在当前代码块有效。如果想设置跨模块常量,可以采用下面的写法。

//constants.js
export const A = 1;
export const B = 2;

//text.js
import  {A,B} from '../assets/js/constants'
console.log(A);
console.log(B);

或者

//constants.js
const A = 1;
const B = 2;
export default {
    A:A,
    B:B
}

//text.js
import  constants from '../assets/js/constants'
console.log(constants.A);
console.log(constants.B);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值