ES2015中let的暂时性死区(TDZ)

Posted liubeimeng

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES2015中let的暂时性死区(TDZ)相关的知识,希望对你有一定的参考价值。

Tomporal Dead Zone (TDZ)是ES2015中对作用域新的专用定义。是对于某些遇到在区块作用域绑定早于声明语句时的情况。Tomporal Dead Zone (TDZ)可以理解为时间上无法达到的区域,简称“时间死区”或者“暂时死区”。

请思考下面代码,结果会是神马?

1 console.log(a);
2 var a = 12;

如果你了解变量预编译过程,变量提升,那么很容易就会知道,这段代码相当于:

1 var a;
2 console.log(a);

因此,会输出undefined

而在ES2016中,使用let命令,会产生什么样的结果:

1 alert(a);
2 let a = 5;

浏览器报错:ReferenceError: a is not defined

原因是,我们忽略了let暂时性死区

如下所示:

1 alert(a);//TDZ暂时性死区
2 let a = 5;//TDZ结束

其他影响,

对TDZ期间中的变量/常量作任何的访问动作,一律会抛出错误,需要注意:

typeof x // "undefined"

{
  // TDZ
  typeof a // ReferenceError
  let a = 12
}

以上是关于ES2015中let的暂时性死区(TDZ)的主要内容,如果未能解决你的问题,请参考以下文章

关于ES6

ES6 中 let 和 const 总结

ES6新特性:let和const

let和const命令 具体参照http://es6.ruanyifeng.com

ES6——字面量的增强解构let/const块级作用域暂时性死区

let和const暂时性死区的问题