ES6从入门到精通:变量

变量声明方式

ES6引入了letconst两种新的变量声明方式,与传统的var形成对比。

let允许声明块级作用域变量,变量仅在当前代码块内有效。const用于声明常量,一旦赋值不可更改,同样具有块级作用域特性。var则存在变量提升和函数级作用域的问题。

块级作用域

使用letconst声明的变量具有块级作用域特性,即变量仅在声明所在的代码块(如ifforwhile等语句的块)内有效。这种特性避免了变量污染全局空间和意外覆盖的问题。

javascript 复制代码
{
  let blockScoped = 'visible inside block';
  const PI = 3.14;
}
console.log(blockScoped); // ReferenceError
console.log(PI); // ReferenceError

暂时性死区

使用letconst声明的变量存在暂时性死区(TDZ)。在变量声明前访问会导致ReferenceError,这与var的变量提升行为不同。这种设计强制了先声明后使用的编程规范。

javascript 复制代码
console.log(a); // ReferenceError
let a = 10;

常量声明

const用于声明常量,必须立即初始化且不能重新赋值。对于对象类型,虽然变量绑定不可变,但对象属性可以修改。这种特性适合声明配置值或不应被重新赋值的引用。

javascript 复制代码
const APP_VERSION = '1.0.0';
APP_VERSION = '2.0'; // TypeError

const user = {name: 'Alice'};
user.name = 'Bob'; // 允许

全局变量声明

在全局作用域中,letconst声明不会成为window对象的属性,这与var不同。这种特性避免了无意中污染全局命名空间的问题。

javascript 复制代码
var globalVar = 'value';
let globalLet = 'value';
console.log(window.globalVar); // 'value'
console.log(window.globalLet); // undefined

循环中的变量

let在循环中表现特殊,每次迭代都会创建新的绑定。这解决了var在循环中共享同一变量的问题,特别适合异步回调场景。

javascript 复制代码
//使用 var
var i = 999
for(var i = 0; i < 3; i++) {
  () => console.log(i);
// 输出0, 1, 2
}
console.log(i)
// 输出3

//使用 let
let i = 999
for(let i = 0; i < 3; i++) {
 () => console.log(i);
// 输出0, 1, 2
}
console.log(i)
// 输出999

重复声明限制

在同一作用域内,letconst不允许重复声明同名变量,而var允许。这种限制有助于避免无意中的变量覆盖。

javascript 复制代码
let x = 1;
let x = 2; // SyntaxError

最佳实践建议

推荐优先使用const,只有当变量需要重新赋值时才使用let。完全避免使用var,除非有特殊兼容性需求。这种实践能带来更可预测的代码行为和更好的可维护性。

对于不应改变的原始值使用const(在栈中的内容),对于需要修改的引用或原始值使用let。对象和数组虽然用const声明,但其内容仍可修改(实际修改的是堆的内容),真正不可变的数据结构需要使用Object.freeze()或其他库。

相关推荐
gis收藏家15 分钟前
从稀疏数据(CSV)创建非常大的 GeoTIFF(和 WMS)
前端
程序视点29 分钟前
望言OCR 2025终极评测:免费版VS专业版全方位对比(含免费下载)
前端·后端·github
NUC_Dodamce1 小时前
Cocos3x 解决同时勾选 适配屏幕宽度和 适配屏幕高度导致Widget组件失效的问题
开发语言·javascript·ecmascript
五点六六六1 小时前
前端常见的性能指标采集
前端·性能优化·架构
吳所畏惧1 小时前
NVM踩坑实录:配置了npm的阿里云cdn之后,下载nodejs老版本(如:12.18.4)时,报404异常,下载失败的问题解决
前端·windows·阿里云·npm·node.js·batch命令
陈随易1 小时前
AI新技术VideoTutor,幼儿园操作难度,一句话生成讲解视频
前端·后端·程序员
Pedantic1 小时前
SwiftUI 按钮Button:完整教程
前端
前端拿破轮2 小时前
2025年了,你还不知道怎么在vscode中直接调试TypeScript文件?
前端·typescript·visual studio code
代码的余温2 小时前
DOM元素添加技巧全解析
前端
JSON_L2 小时前
Vue 电影导航组件
前端·javascript·vue.js