本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。
什么是暂时性死区
ES6中,在代码块内,使用let/const命令声明变量之前,该变量都是不可用的,在变量声明之前属于该变量的“死区”。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。ES标准并没有明确提出TDZ,但我们常用其描述let、const的不提升效果。
(相关资料图)
let/const和var的区别
在ES6之前,JS的scope只有两种,全局作用域和函数作用域,但是在ES6种出现了块级作用域,即使用let/const可以定义块级作用域。那么在ES6的新特性中,最容易看到TDZ作用的就是使用let/const的使用上面。let/const与var的主要不同有两个地方:
let/const是使用区块作用域;var是使用函数作用域在let/const声明之前就访问对应的变量与常量,会抛出ReferenceError错误;但在var声明之前就访问对应的变量,则会得到undefinedconsole.log(Vname); // undefined;console.log(Lname); // ReferenceErrorvar Vname = "xiaoxiao";let Lname = "xiaoxiao";
登录后复制
实践证明当我们在未声明之前使用var定义的变量时会得到undefined,但是在使用let未定义的变量时会抛出错误。因为ES6中的let声明的变量是不存在变量提升的作用。
var x = 10;if (true) { x = 20; // ReferenceError let x; }
登录后复制
ES6 明确规定,如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。总之,在代码块内,使用let命令声明变量之前,该变量都是不可用的。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。
if (true) { // TDZ开始 tmp = "abc"; // ReferenceError console.log(tmp); // ReferenceError let tmp; // TDZ结束 console.log(tmp); // undefined tmp = 123; console.log(tmp); // 123}
登录后复制
上面代码中,在let命令声明变量tmp之前,都属于变量tmp的“死区”。
typeof的“死区”陷阱
我们都知道使用typeof 可以用来检测给定变量的数据类型,也可以使用它来判断值是否被定义。当返回undefined时表示值未定义;但是在const/let定义的变量在变量声明之前如果使用了typeof就会报错
typeof x; // ReferenceErrorlet x;
登录后复制
因为x是使用let声明的,那么在x未声明之前都属于暂时性死区,在使用typeof时就会报错。所以在使用let/const进行声明的变量在使用typeof时不一定安全喔。
typeof y; // "undefined"
登录后复制
但是可以看出,如果我们只是用了typeof而没有去定义,也是不会报错的,从这粒可以看出只要没有明确规定使用const/let定义之前就是不会出错。
传参的“死区”陷阱
例如下面一段代码,我们在使用
function bar(x = y, y = 2) { return [x, y];}bar(); // 报错
登录后复制
上面代码中,调用bar函数之所以报错(某些实现可能不报错),是因为参数x默认值等于另一个参数y,而此时y还没有声明,属于”死区“。如果y的默认值是x,就不会报错,因为此时x已经声明了。
function bar(x = 2, y = x) { return [x, y];}bar(); // [2, 2]
登录后复制
使用var和let声明的另外一种区别。
// 不报错var x = x;// 报错let x = x;// ReferenceError: x is not defined
登录后复制
受“死区”的影响,使用let声明变量时,只要变量在还没有声明完成前使用,就会报错。上面这行就属于这个情况,在变量x的声明语句还没有执行完成前,就去取x的值,导致报错”x 未定义“。
总结
ES6 规定暂时性死区和let、const语句不出现变量提升,主要是为了减少运行时错误,防止在变量声明前就使用这个变量,从而导致意料之外的行为。这样的错误在 ES5 是很常见的,现在有了这种规定,避免此类错误就很容易了。
总之,暂时性死区的本质就是,只要一进入当前作用域,所要使用的变量就已经存在了,但是不可获取,只有等到声明变量的那一行代码出现,才可以获取和使用该变量。
【相关推荐:javascript视频教程、web前端】
以上就是es6暂时性死区是什么意思的详细内容,更多请关注php中文网其它相关文章!