登录
首页 >  文章 >  前端

let和const如何替代var【教程】

时间:2026-03-28 14:02:36 414浏览 收藏

ES6 引入的 let 和 const 并非 merely “替代” var 的可选方案,而是从根本上解决其设计缺陷的现代变量声明方式:它们提供真正的块级作用域、杜绝变量提升、禁止同作用域重复声明,并避免全局污染(var 在顶层会意外挂载到 window 上);const 约束的是变量绑定而非值本身,因此适用于所有不需重新赋值的场景(包括空对象或数组),而 let 则天然修复循环中 notorious 的闭包问题,让异步逻辑更可靠;在当今开发实践中,var 已无合理存在理由——弃用它不是优化建议,而是保障代码健壮性、可维护性与团队协作安全性的必要底线。

javascript中let和const如何取代var【教程】

不用再刻意“取代”var,ES6 起 letconst 就是为解决 var 的设计缺陷而生的——块级作用域、无变量提升、重复声明报错。实际编码中,var 应该被完全弃用。

为什么 var 在函数外声明会挂到 window

var 声明的变量在全局作用域下会成为全局对象(浏览器中是 window)的属性,这是历史遗留行为;而 letconst 不会。

  • var a = 1window.a1
  • let b = 2window.bundefined
  • const c = 3window.cundefined

这直接影响模块隔离和污染控制,尤其在多人协作或微前端场景下,用 var 容易意外覆盖已有全局变量。

letconst 的核心区别不是“可变/不可变”,而是“是否允许重新赋值”

const 约束的是绑定(binding),不是值本身。对象或数组用 const 声明后,仍可修改其属性或元素;但不能对变量名重新赋值。

  • const obj = { x: 1 }; obj.x = 2; ✅ 合法
  • const arr = []; arr.push(1); ✅ 合法
  • const obj = {}; obj = { y: 2 }; ❌ 报错:TypeError: Assignment to constant variable
  • let count = 0; count = 1; ✅ 合法

所以判断用哪个,只看一个标准:这个变量后续会不会被重新赋值。会 → let;不会 → const(哪怕它是个空数组或空对象)。

循环中闭包问题:用 var 会出 bug,let 天然修复

经典问题:for (var i = 0; i console.log(i), 0) 输出三个 3,因为 var 是函数作用域,所有回调共享同一个 i

  • let:每次迭代都创建新绑定 → 输出 012
  • const 在 for 循环中需配合 for...of 或解构,例如:for (const item of [1,2,3]) { ... }
  • 不推荐用 var + IIFE 模拟块级作用域来绕过——写法冗余且易读性差

现代代码里,只要涉及循环内异步或回调,优先选 let,几乎不需要手动模拟作用域。

真正容易被忽略的是:即使在严格模式下,var 依然允许重复声明(同作用域内多次 var x 不报错),而 let/const 一旦重复就会抛 SyntaxError。这个差异在大型项目重构或拼接脚本时可能引发静默覆盖,务必警惕。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>