-
作用域:
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
相关推荐
一颗不甘坠落的流星几秒前
【HTML】iframe 标签 allow 权限汇总(例如添加复制粘贴权限)forestsea7 分钟前
现代 JavaScript 加密技术详解:Web Crypto API 与常见算法实践骑自行车的码农1 小时前
🍂 React DOM树的构建原理和算法北极糊的狐1 小时前
Vue3 中父子组件传参是组件通信的核心场景,需遵循「父传子靠 Props,子传父靠自定义事件」的原则,以下是资料总结看到我请叫我铁锤2 小时前
vue3中THINGJS初始化步骤q***25212 小时前
SpringMVC 请求参数接收谢尔登3 小时前
defineProperty如何弥补数组响应式不足的缺陷T***u3334 小时前
前端框架在性能优化中的实践jingling5555 小时前
vue | 在 Vue 3 项目中集成高德地图(AMap)芳草萋萋鹦鹉洲哦14 小时前
【elemen/js】阻塞UI线程导致的开关卡顿如何优化