-
作用域:
var
声明的变量具有全局作用域和函数作用域,可以跨块访问。let
和const
声明的变量还具有块级作用域,意味着它们在声明它们的块(例如,if 块、for 块、函数块等)内可见。(之前没有块作用域的时候,if 或者 for 等中声明的变量会泄露全局变量,其次 {} 中的内层变量可能会覆盖外层变量,块作用域解决了这些问题)
-
变量提升:
var
声明的变量会被提升到其作用域的顶部。这意味着可以在声明变量之前访问它们,但它们的值将是undefined
。let
和const
不会发生变量提升,存在暂时性死区(TDZ)。在声明之前访问let
或const
变量会导致 ReferenceError。
-
重复声明:
- 在相同的作用域中,使用
var
可以多次声明同一变量而不会报错。 - 使用
let
或const
在相同的作用域中重复声明同一变量会导致 SyntaxError。
- 在相同的作用域中,使用
-
可变性:
- 使用
var
声明的变量可以随时重新赋值,并且可以修改其值和类型。 - 使用
let
声明的变量也可以重新赋值,但不能重新声明。 - 使用
const
声明的变量必须进行初始化,并且不能被重新赋值。但这并不意味着它们是不可变的,如果是引用类型的值,可以修改其属性。
- 使用
【JavaScript】let,const 和 var 的区别
谢尔登2024-05-03 8:18
相关推荐
前端付豪1 天前
1、震惊!99% 前端都没搞懂的 JavaScript 类型细节朝与暮1 天前
js符号(Symbol)大怪v1 天前
前端:人工智能?我也会啊!来个花活,😎😎😎“自动驾驶”整起!遂心_1 天前
为什么 '1'.toString() 可以调用?深入理解 JavaScript 包装对象机制王同学QaQ1 天前
Vue3对接UE,通过MQTT完成通讯程序员鱼皮1 天前
刚刚 Java 25 炸裂发布!让 Java 再次伟大Asort1 天前
JavaScript 从零开始(五):运算符和表达式——从零开始掌握算术、比较与逻辑运算一枚前端小能手1 天前
🚀 缓存用错了网站更慢?前端缓存策略的5个致命误区艾小码1 天前
为什么你的页面会闪烁?useLayoutEffect和useEffect的区别藏在这里!艾小码1 天前
告别Vue混入的坑!Composition API让我效率翻倍的3个秘密