信息发布→ 登录 注册 退出

什么是变量作用域_javascript中let和const有何区别?

发布时间:2025-12-17

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

变量作用域指的是变量在代码中能被访问的范围。JavaScript 中,letconst 都是块级作用域,而 var 是函数作用域(或全局作用域),这是最核心的区别。理解作用域,才能避免变量污染、意外覆盖和引用错误。

let 和 const 的作用域完全相同

它们都只在声明所在的花括号 {} 内有效——包括 ifforwhile、函数体内部等任意块级结构。

  • 在块外访问会报错: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 声明时必须紧跟一个初始值,没有默认值,也不允许留空。

  • const name; ❌ 语法错误:Missing initializer in const declaration
  • let age; ✅ 合法,此时 ageundefined
  • const user = {}; ✅ 推荐写法:用 const 声明对象/数组,再逐步填充内容

它们都不会挂载到全局 window 对象上

在浏览器中,var 在全局作用域声明会自动成为 window 的属性,容易造成命名冲突;而 letconst 不会。

  • 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  # java  # 编码  # 浏览器  # ai  # win  # 区别  # 作用域  
在线客服
服务热线

服务热线

4008888355

微信咨询
二维码
返回顶部
×二维码

截屏,微信识别二维码

打开微信

微信号已复制,请打开微信添加咨询详情!