es6 let 和 const 命令

let命令

let命令声明的变量,只在let所在的块级作用域有效
{
    let a = 10;
    var b = 20;
}
a;  // a is not defined
b;  // 20
var arry = [];
for (let i = 0;i < 5;i++>) {
    arry[i] = function () {
        console.log(i);
    }
}
arry[3] // 3    let会为循环体的每一次执行产生一个作用域

如果将循环中的let写为var,则arry[3]会输出5

let命令不存在声明提前
console.log(a);     // 报错
console.log(b);     // undefined
let a = 1;
var b = 1; 

所以使用let的时候一定要先声明再使用。
let会绑定块级作用域,封闭作用域,即在块级作用域中,let声明变量之前,该变量不能被使用,这种被称为暂时性死区。

{
    a = 1;              // 报错
    console.log(a);     // 报错
    let a;
    console.log(a);     // undefined
    a = 1;
    console.log(a);     // 1
}

总之,let声明的变量,在let声明之前都不能被使用。只要一进入块级作用域,此变量就已经被占用了,只有被声明之后,才可以使用此变量。

不允许变量的重复声明
{
    let a = 2;
    var a = 3;      //报错
}
{
    let a = 2;
    let a = 3;      //报错
}

const 命令

const 命令用于声明常量。
const和let命令一样,在块级作用域有效,不存在声明提前,存在暂时性死区,不能重复声明。(这里不多做展示了)

const a = 1;
a = 2;          // 报错

const声明变量时,要立即赋值,不然也会报错。

猜你喜欢

转载自blog.csdn.net/weixin_42613755/article/details/80933553