2016-11-16
和 Var 不同的是, let 作用域仅在它所在的代码块,比如说一个 for-loop
for(let i=0;i<1;i++){}
用这种方法可以使代码变量更加合理,比如说在以上的循环中,如果使用 var, 在外部调用 i 也可以返回最后一个 for-loop 中 i 的位置.
在 for 中,循环语句和内容是两个不同的作用域,比如说以下的代码
for (let i = 0; i < 3; i++) {
let i = 'abc';
console.log(i);
}
输出是3次 abc, 这意味着 i 被重新定义了
let 是不存在变量提升的,声明var 变量的时候,有时(因为我自己测试的时候感觉很迷)会出现变量提升,就是说在开始执行代码的时候,在实际声明变量之前,其就已经存在了但是没有值,声明变量的时候是在给一个 undefined 的变量赋值! 真的迷,但是到时挺好用的
// var 的情况
console.log(foo); // 输出undefined
var foo = 2;
// let 的情况
console.log(bar); // 报错ReferenceError
let bar = 2;
这是一个变量提升的例子, 在 var 中,明明还没有声明 foo, 但是却有一个叫做 foo 的 undefined 变量莫名其妙的可以调用
暂时性死区
var tmp = 123;
if (true) {
tmp = 'abc'; // ReferenceError
let tmp;
}
代码说明一切,在实际声明 tmp 之前,tmp 变量都是不可用的,直到声明它
var tmp = 123;
if (true) {
tmp = 'abc'; // good
}
如果不在作用域声明 let tmp 就可以正常使用