一、let命令
let用来声明变量,类似于var,但是let声明的变量只在let命令所在的代码块内有效。
{
var a = 10;
let b = 5;
console.log(a); //10
console.log(b); //5
}
console.log(a); //10
console.log(b); //ReferenceError: b is not defined
在for循环中使用let非常合适:
for(let i = 0; i < 10; i++) {
//...
}
console.log(i); //ReferenceError: a is not defined.
如果是在for循环中使用var,则最后输出的会是10:
var a = [];
for (var i = 10; i < 10; i++) {
a[i] = function() {
console.log(i);
};
}
a[6](); //10
如果使用的是let,则会输出6;另外在for循环中 还有一个特别之处,就是设置循环变量的那一部分是一个父作用域,而循环体内部是一个单独的子作用域:
for(let i = 0; i < 3; i++) {
let i = 'qwe';
console.log((i);
}
//qwe
//qwe
//qwe
let不存在变量提升,一定要在声明后再使用;
let不允许在相同的作用域内,重复声明同一个变量;
二、块级作用域
ES5只有全局作用域和函数作用域,没有块级作用域;
允许在块级作用域内声明函数。
函数声明类似于var
,即会提升到全局作用域或函数作用域的头部。
同时,函数声明还会提升到所在的块级作用域的头部。
三、const命令
const声明一个只读的常量。一旦声明,常量的值就不能改变,并必须立即初始化,不能留到以后赋值,不可重复声明。
const的作用域和let命令相同:只在声明所在的块级作用域内有效。
const命令声明的常量也是不提升,同样存在暂时性死区,只能在声明的位置后使用。