【js篇】JavaScript 中的包装类型详解var、let、const 的区别详解

在 JavaScript 中,变量的声明方式经历了从 varletconst 的演变。letconst 是 ES6(ECMAScript 2015)引入的新语法,解决了 var 存在的一些问题,使代码更加安全和可维护。


✅ 一、主要区别对比表

特性 var let const
是否有块级作用域 ❌ 否 ✅ 是 ✅ 是
是否存在变量提升 ✅ 是 ❌ 否 ❌ 否
是否添加全局属性(如 window ✅ 是 ❌ 否 ❌ 否
能否重复声明变量 ✅ 是 ❌ 否 ❌ 否
是否存在暂时性死区(TDZ) ❌ 否 ✅ 是 ✅ 是
是否必须设置初始值 ❌ 否 ❌ 否 ✅ 是
能否改变指针指向 ✅ 是 ✅ 是 ❌ 否

✅ 二、逐项解析

1️⃣ 块级作用域(Block Scope)

  • var 没有块级作用域,只区分函数作用域;
  • letconst 有块级作用域 ,由 {} 包裹的区域就是它们的作用域;

示例:

javascript 复制代码
if (true) {
  var a = 1;
  let b = 2;
  const c = 3;
}
console.log(a); // 1(var 可以访问)
console.log(b); // ReferenceError: b is not defined
console.log(c); // ReferenceError: c is not defined

📌 总结:

使用 letconst 更加安全,避免了变量污染和意外覆盖。


2️⃣ 变量提升(Hoisting)

  • var 存在变量提升 :变量会被提升到作用域顶部,并初始化为 undefined
  • letconst 不会提升,但会进入"暂时性死区";

示例:

javascript 复制代码
console.log(a); // undefined(变量被提升)
var a = 1;

console.log(b); // ReferenceError: Cannot access 'b' before initialization
let b = 2;

console.log(c); // ReferenceError: Cannot access 'c' before initialization
const c = 3;

📌 总结:

letconst 避免了因变量提升导致的错误逻辑。


3️⃣ 是否添加全局对象属性

  • 在浏览器中,全局对象是 window,Node.js 中是 global
  • var 声明的变量会成为全局对象的属性
  • letconst 不会

示例:

javascript 复制代码
var a = 10;
console.log(window.a); // 10

let b = 20;
console.log(window.b); // undefined

const c = 30;
console.log(window.c); // undefined

📌 总结:

使用 letconst 更加安全,不会污染全局命名空间。


4️⃣ 能否重复声明变量

  • var 允许重复声明
  • letconst 不允许重复声明

示例:

javascript 复制代码
var x = 1;
var x = 2; // 合法

let y = 1;
let y = 2; // SyntaxError: Identifier 'y' has already been declared

const z = 1;
const z = 2; // SyntaxError: Identifier 'z' has already been declared

📌 总结:

letconst 提高了代码的健壮性,防止重复定义带来的混乱。


5️⃣ 暂时性死区(Temporal Dead Zone, TDZ)

  • letconst 存在 TDZ:变量在声明前不可访问;
  • var 没有 TDZ

示例:

javascript 复制代码
console.log(a); // undefined
var a = 1;

console.log(b); // ReferenceError
let b = 2;

console.log(c); // ReferenceError
const c = 3;

📌 总结:

TDZ 是一种语言设计机制,确保变量在声明之前不能被使用,提高了代码的可读性和安全性。


6️⃣ 是否必须设置初始值

  • varlet 可以不设置初始值
  • const 必须设置初始值

示例:

javascript 复制代码
var a; // OK
let b; // OK
const c; // SyntaxError: Missing initializer in const declaration

📌 总结:

const 强制开发者在声明常量时就赋值,有助于编写更清晰的代码。


7️⃣ 是否能改变指针指向

  • varlet 可以重新赋值
  • const 不可以改变指针指向(注意:如果是对象或数组,内容是可以修改的);

示例:

javascript 复制代码
var a = 1;
a = 2; // OK

let b = 1;
b = 2; // OK

const c = 1;
c = 2; // TypeError: Assignment to constant variable.

const obj = { name: "Tom" };
obj.name = "Jerry"; // OK,修改对象内容
obj = {}; // TypeError: Assignment to constant variable.

📌 总结:

const 表示的是引用不变,不是值不可变。对于对象或数组,仍可以修改其内容。


✅ 三、一句话总结

  • var 是函数作用域,存在变量提升和重复声明的问题;
  • let 是块级作用域、不可重复声明、没有变量提升;
  • constlet 类似,但必须初始化且不可重新赋值;
  • 推荐优先使用 const,其次是 let,避免使用 var

💡 进阶建议

  • 使用 TypeScript 时,const 会带来更强的类型推导优势;
  • 使用 ESLint 规则禁止使用 var
  • 在 Vue / React 开发中,推荐用 constlet 管理状态;
  • 使用 Object.freeze() 配合 const 实现真正不可变的数据结构;
相关推荐
wyiyiyi16 分钟前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
gnip38 分钟前
vite和webpack打包结构控制
前端·javascript
excel1 小时前
在二维 Canvas 中模拟三角形绕 X、Y 轴旋转
前端
阿华的代码王国1 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端
一条上岸小咸鱼1 小时前
Kotlin 基本数据类型(三):Booleans、Characters
android·前端·kotlin
Jimmy1 小时前
AI 代理是什么,其有助于我们实现更智能编程
前端·后端·ai编程
ZXT2 小时前
promise & async await总结
前端
Jerry说前后端2 小时前
RecyclerView 性能优化:从原理到实践的深度优化方案
android·前端·性能优化
画个太阳作晴天2 小时前
A12预装app
linux·服务器·前端
7723892 小时前
解决 Microsoft Edge 显示“由你的组织管理”问题
前端·microsoft·edge