暂时性死区

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值