在掘金的分享文章当中看到了关于es6 const 和 let变量声明是否提升的文章,学到了很多。
const、 let、class 和、var、function定义一样都存在变量提升。只不过是初始化的不同表现才使得前面一组定义和后一组不太一样
在变量提升后,var 会给变量初始值undefined。而let等定义方式是未初始化,也就是什么值都没有。这就意味着当你尝试去读取值的时候会报错。所以会有一个暂时性死区的感念。这个区间就是在未进行初始化前,进行值得访问。
x = y = "global";
(function() {
x; // undefined
y; // Reference error: y is not defined
var x = "local";
let y = "local";
}());
简单结论
- let 的「创建」过程被提升了,但是初始化没有提升。
- .var 的「创建」和「初始化」都被提升了。
- function 的「创建」「初始化」和「赋值」都被提升了。