JavaScript新增的let变量作用

本文探讨了JavaScript中let与var定义变量的区别,let解决了var存在的块作用域缺失、全局变量污染及变量提升等问题,更适用于现代编程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JavaScript中使用var定义变量可能存在以下问题:
1.var 定义的变量没有块作用域。
2.var 定义的全局变量会自动添加全局window对象的属性。
3.var定义的变量会提前装载。
let 关键字正是为了解决上述问题而出现的,
1.
在这里插入图片描述
上面程序在for循环中使用let来定义循环计数器,这样i将只会在for循环中有效,因此程序在循环体外访问i就会报错,如果将let改为var,那么在循环体中定义的i就会扩散到循环体之外。
2.
在这里插入图片描述
上面代码 使用let定义了个name,这个name不在任何函数中,所以是个全局变量。但与var定义的全局变量不同的是,使用let定义的全局变量不会变成window对象的属性,因此上面代码输出window.name时看不到任何输出。
3.
使用var定义的变量会提前装载,而使用let定义的变量要等到程序流执行到定义变量的代码是才会装载。
在这里插入图片描述
上面程序先定义了一个全局的name变量,接下来在func()函数中使用let定义了一个局部变量name,此时局部变量name会完全覆盖全部变量name,由于使用let定义的局部变量不会提前装载,因此访问let上面那个name变量会导致错误。如果将let改为var定义,则会先输出 undefined,再输出局部变量name的值。
综上所述,let关键字的出现正是为了弥补var的缺陷,因此对于支持let的浏览器,读者应该考虑使用let代替var.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值