## let
基本用法: let是用来生命变量。用法类似于var,但是let命令只在所处的代码块有效。
{ var a = 10; let b = 20; } console.log(a) //10 console.log(b) //referenceError: a is not defined.
可以避免产生闭包:比如for循环。
//var 声明的i在全局范围内都有效,每次循环都会覆盖旧值。产生闭包。 for (var i = 0; i < 10; i ++) { a[i] = function () { console.log(i); } } a[6]() ; // 10 //let 声明的i只在本轮循环有效,所以每一次循环的i都是一个新的变量。 for (let i = 0; i < 10; i ++) { a[i] = function () { console.log(i); } } a[6](); //6
不存在变量声明提升。
console.log(foo); //2 console.log(bar); //refferenceError 报错 var foo = 2; let bar = 2;
暂时性死区。
var tmp = 123; if (true) { tmp = 'abc'; //referenceError let tmp; }
上面代码中,存在全局变量tmp,但是块级作用域内let又声明了一个全局变量tmP,导致后者绑定这个块级作用域,所以在let变量声明之前,对tmp的赋值会报错。
ES6中明确规定,如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域,凡是在声明之前就使用这些变量就会报错。
使用typeof也是同理。在出现let等方式之前,typeof百分百不会报错,但是这种情况下,并不安全。与赋值同样会报错。
es6一共有6种声明变量的方法:
var 、function 、let 、const 、import、 class。