失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > 暂时性死区

暂时性死区

时间:2019-11-19 03:14:45

相关推荐

暂时性死区

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没有暂时性死区

如果觉得《暂时性死区》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。
相关阅读
JS 暂时性死区

JS 暂时性死区

2021-03-06

JavaScript中暂时性死区

JavaScript中暂时性死区

2019-11-11

let的暂时性死区

let的暂时性死区

2018-06-08

let暂时性死区理解

let暂时性死区理解

2023-01-09