console.log(a);
var a = 1;
上面的代码的运行结果为undefined,这是因为var存在变量提升,相当于
var a;
console.log(a);
a = 1;
然而当a用let来声明时
console.log(a);
let a = 1;
这时将会报错,这被称为暂时性死区。
暂时性死区的具体解释为:在代码块内,使用let和const命令声明变量之前,该变量都是不可用的,语法上被称为暂时性死区。
那么暂时性死区产生的原因是什么呢?
ES6对暂时性死区的解释为
当程序的控制流程在新的作用域(module function 或 block作用域)进行实例化时,在此作用域中用let/const声明的变量会先在作用域中被创建出来,但因此时还未进行词法绑定,所以是不能被访问的,如果访问就会抛出错误。因此,在这运行流程进入作用域创建变量,到变量可以被访问之间的这一段时间,就称之为暂时死区。
即let/const声明的变量在未出现声明变量的那一行代码之前没有进行词法绑定,无法被访问。
暂时性死区的本质就是,只要一进入当前作用域,所要使用的变量就已经存在了,但是不可获取,只有等到声明变量的那一行代码出现,才可以获取和使用该变量。
那么为什么var没有暂时性死区?
我们知道,let/const作用域为块级作用域,变量不会提升;而var的作用域为全局作用域,可以进行变量提升,这也就是为什么var没有暂时性死区