寒假javascript补习班 第二章 let&const暂时性死区

暂时性死区的表现

if (true) {

console.log(value);

let value = 1;

}

Uncaught ReferenceError: Cannot access 'value' before initialization

var:
1、在ES5中是全局变量、顶级变量(指window)

2、存在变量提升的情况

console.log(a)  //undefined
var a=10
这段代码将转换成下述

var a
consolse.log(a)
a=10
3、可以重复声明,最终结果为最后一个将前面变量进行覆盖

4、在函数内使用var是局部变量,在函数内直接使用变量为全局变量(无var)

let:
1、let的作用域是块级代码,只在代码块中有效。

2、不存在变量提升(暂时性死区)

3、不允许重复定义

const:
1、const声明一个只读的常量,一旦声明,常量的值就不能改变

2、如果之前用var或let声明过变量,再用const声明同样会报错

3、不存在变量提升(暂时性死区)

这也体现出了let和const的安全性可言

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小鱼程序员

你的鼓励将是我创作的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值