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 —— 除非你明确知道这个变量后续要重新赋值。这既是编码习惯,也是让代码更安全、更易读的关键细节。











