JavaScript中let和const是块级作用域,var是函数或全局作用域;二者均具TDZ、不可重复声明、不挂载window等特性,但const必须初始化且不可重新赋值,推荐优先使用const。

变量作用域指的是变量在代码中能被访问的范围。JavaScript 中,let 和 const 都是块级作用域,而 var 是函数作用域(或全局作用域),这是最核心的区别。理解作用域,才能避免变量污染、意外覆盖和引用错误。
let 和 const 的作用域完全相同
它们都只在声明所在的花括号 {} 内有效——包括 if、for、while、函数体内部等任意块级结构。
在块外访问会报错:ReferenceError: xxx is not defined 同一作用域内不能重复声明,否则直接语法错误 都存在“暂时性死区”(TDZ):在声明语句执行前访问,哪怕在同一块内,也会报错
let 可重新赋值,const 不可重新赋值
let 声明的是可变绑定,适合需要后续修改值的变量;const 声明的是不可变绑定,强调“这个变量名始终指向同一个值”。
let count = 1; count = 2; ✅ 合法 const PI = 3.14; PI = 3.1415; ❌ 运行时报错:TypeError: Assignment to constant variable const obj = {a: 1}; obj.a = 2; ✅ 合法(对象内容可变,只是不能把 obj 指向新对象) const arr = [1]; arr.push(2); ✅ 合法;但 arr = [3]; ❌ 报错
const 必须初始化,let 可以暂不赋值
const 声明时必须紧跟一个初始值,没有默认值,也不允许留空。
立即学习“Java免费学习笔记(深入)”;
const name; ❌ 语法错误:Missing initializer in const declaration let age; ✅ 合法,此时 age 是 undefined const user = {}; ✅ 推荐写法:用 const 声明对象/数组,再逐步填充内容
它们都不会挂载到全局 window 对象上
在浏览器中,var 在全局作用域声明会自动成为 window 的属性,容易造成命名冲突;而 let 和 const 不会。
var dog = 'wangcai'; console.log(window.dog); → 输出 "wangcai" let cat = 'miaomiao'; console.log(window.cat); → undefined const bird = 'tweety'; console.log(window.bird); → undefined
基本上就这些。选 let 还是 const,优先用 const —— 除非你明确知道这个变量后续要重新赋值。这既是编码习惯,也是让代码更安全、更易读的关键细节。
以上就是什么是变量作用域_javascript中let和const有何区别?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1543393.html
微信扫一扫
支付宝扫一扫