ES6 let命令


let命令用来声明变量,使用方式与var命令一样。但是二者的作用有区别: let声明的变量只在let声明的代码块中有效,且不存在变量提升。另外,在相同的作用域内,使用let声明同一个变量是不允许的。

代码块中有效

如下代码,输出的i为10,说明使用var变量声明的变量,就算是离开了代码块,依然是有效的。

for(var i = 0; i < 10; ++i){
}
console.log(i)

现在只需要将var改成let:

for(let i = 0; i < 10; ++i){
}
console.log(i)

结果提示了错误信息:ReferenceError: i is not defined。
由此得出的结论是:var声明的变量是全局的,而let声明的变量只在该代码块中有效。

变量提升

同样,在使用var定义变量i之前,就打印出i,显示的结果为:undefined。这说明var定义的变量i被提升了,只是说现在还没有值,所以为undefined。

console.log(i)
for(var i = 0; i < 10; ++i){
}

如果把var改成let:

console.log(i)
for(let i = 0; i < 10; ++i){
}

结果提示了错误信息:ReferenceError: i is not defined。
由此得出的结论是:变量用var声明,会发生变量提升;用let声明,不会发生变量提升;

暂时性死区

ES6 明确规定,如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。

var a = 10;
{
	a = 3;
    let a = 4;
}

执行以上代码,结果会报错:ReferenceError: can’t access lexical declaration `a’ before initialization。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值