let与var
1、let声明的变量是块级作用域(只在所声明的代码块内有效)。在ES6之前,js只存在函数作用域以及全局作用域。
if(1){
let a=1;
console.log(a)//1
}
console.log(a)//ReferenceError: a is not defined
2、let不存在变量提升(必须遵循“先声明,后使用”的原则)
console.log(a); //ReferenceError: b is not defined
let a=2;
3、let在同一作用域内不能重复定义
let a=5;
let a=5;
console.log(a);//Uncaught SyntaxError: Identifier 'a' has already been declared
4、暂时性死区:在代码块内,使用let声明变量之前,该变量都是不可以使用的
let a =1;
function fn(){
console.log(a);
let a = 2;
}
fn();//Uncaught ReferenceError: Cannot access 'a' before initialization
ES6规定,如果在区块中存在let和const声明的变量,则这个区块对这些声明的变量从一开始就形成一个封闭的作用域。不管在外部有没有声明这个变量。必须遵守“先声明,后使用”的原则,否则报错
暂时性死区的本质就是,只要一进入当前作用域,所使用的变量就已存在,但是不可获取,只有等到声明变量的哪一行代码的出现,在可以获取和使用该变量
暂时性死区的意义:让我们标准化代码。将所有的变量的声明放在作用域的最开始,主要是为了减少运行程序的错误,防止出现“先使用(变量),后声明(变量)”的情况
const命令的基本使用
1、只在块级作用域内有效
2、必须先声明,后使用
3、在同一作用域,const不能重复声明同一常量
4、const声明的常量不能改变(不能先声明,后初始化)
const b = 1;
b = 2;
console.log(a);//Uncaught TypeError: Assignment to constant variable.