分享更有价值
被信任是一种快乐

es6暂时性死区指的是什么

文章页正文上

这篇“es6暂时性死区指的是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“es6暂时性死区指的是什么”文章吧。 在es6中,暂时性死区是一个语法错误,是指let和const命令使区块形成封闭的作用域。在代码块内,使用let/const命令声明变量之前,该变量都是不可用的,在变量声明之前属于该变量的“死区”;这在语法上,称为“暂时性死区”。ES6规定暂时性死区和let、const语句不出现变量提升,主要是为了减少运行时错误,防止在变量声明前就使用这个变量,从而导致意料之外的行为。什么是暂时性死区 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声明之前就访问对应的变量,则会得到undefined

console.log(Vname);//undefined;
console.log(Lname);//ReferenceError
varVname='xiaoxiao';
letLname='xiaoxiao';

实践证明当我们在未声明之前使用var定义的变量时会得到undefined,但是在使用let未定义的变量时会抛出错误。因为ES6中的let声明的变量是不存在变量提升的作用。

varx=10;
if(true){
x=20;//ReferenceError
letx;
}

ES6 明确规定,如果区块中存在let和const命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。
总之,在代码块内,使用let命令声明变量之前,该变量都是不可用的。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。

if(true){
//TDZ开始
tmp='abc';//ReferenceError
console.log(tmp);//ReferenceError

lettmp;//TDZ结束
console.log(tmp);//undefined

tmp=123;
console.log(tmp);//123
}

上面代码中,在let命令声明变量tmp之前,都属于变量tmp的“免费云主机、域名死区”。typeof的“死区”陷阱我们都知道使用typeof 可以用来检测给定变量的数据类型,也可以使用它来判断值是否被定义。当返回undefined时表示值未定义;
但是在const/let定义的变量在变量声明之前如果使用了typeof就会报错

typeofx;//ReferenceError
letx;

因为x是使用let声明的,那么在x未声明之前都属于暂时性死区,在使用typeof时就会报错。所以在使用let/const进行声明的变量在使用typeof时不一定安全喔。

typeofy;//'undefined'

但是可以看出,如果我们只是用了typeof而没有去定义,也是不会报错的,从这粒可以看出只要没有明确规定使用const/let定义之前就是不会出错。传参的“死区”陷阱例如下面一段代码,我们在使用

functionbar(x=y,y=2){
return[x,y];
}

bar();//报错

上面代码中,调用bar函数之所以报错(某些实现可能不报错),是因为参数x默认值等于另一个参数y,而此时y还没有声明,属于”死区“。如果y的默认值是x,就不会报错,因为此时x已经声明了。

functionbar(x=2,y=x){
return[x,y];
}
bar();//[2,2]

使用var和let声明的另外一种区别。

//不报错
varx=x;

//报错
letx=x;
//ReferenceError:xisnotdefined

受“死区”的影响,使用let声明变量时,只要变量在还没有声明完成前使用,就会报错。上面这行就属于这个情况,在变量x的声明语句还没有执行完成前,就去取x的值,导致报错”x 未定义“。以上就是关于“es6暂时性死区指的是什么”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注云技术行业资讯频道。

相关推荐: 模板语言是否可以用vue

本篇内容主要讲解“模板语言是否可以用vue”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“模板语言是否可以用vue”吧! 首先,什么是模板语言模板语言是一种标记语言,它使用特定的标记来定义数据对应的展示形式,并在运行…

文章页内容下
赞(0) 打赏
版权声明:本站采用知识共享、学习交流,不允许用于商业用途;文章由发布者自行承担一切责任,与本站无关。
文章页正文下
文章页评论上

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册