const ‘不可变’到底是值不变还是地址不变

const的基础规则

  • 声明时必须初始化
javascript 复制代码
const a; // ❌ 报错:Missing initializer in const declaration
const b = 10; // ✅ 正确
  • 块级作用域(const 的作用域仅限于声明它的代码块)
javascript 复制代码
if (true) {
  const x = 100;
}
console.log(x); // ❌ 报错:x is not defined
  • 不可重复声明(同一作用域内不能重复声明同名变量)
javascript 复制代码
const z = 30;
const z = 40; // ❌ 报错:Identifier 'z' has already been declared
  • 值不可重新赋值("不可变"的本质:是const最容易误解的点------它限制的是变量绑定(即变量指向的内存地址不可变),而不是变量的值不可变。)

原始类型(Primitive Types)

包括:Number、String、Boolean、Undefined、Null、Symbol(ES6新增)、BigInt(ES2020新增)。它们的特点是:直接存储在内存栈中。

  • 值不可变:因为原始类型的值直接存储在变量绑定的内存地址中。
javascript 复制代码
const a = 10;
a = 20; // 报错!不能重新赋值(地址不可变)
  • 本质:a 的地址指向的是值 10,const 禁止修改这个绑定。

复杂数据类型:地址不可变,内容可变

复杂数据类型(如Object、Array、Function)的存储方式不同:变量在栈中存储堆内存地址,实际数据存放在内存堆中。

  • 地址不可变,但值可变:const 确保变量始终指向同一个内存地址(引用),但对象/数组的内容可以修改。
javascript 复制代码
const obj = { name: "Alice" };
obj.name = "Bob"; // 合法!修改对象属性
obj = {};         // 报错!不能重新赋值(地址不可变)
  • 本质:obj 的地址指向同一个对象,但对象的属性是可变的。
相关推荐
知识分享小能手2 小时前
uni-app 入门学习教程,从入门到精通,uni-app基础扩展 —— 详细知识点与案例(3)
vue.js·学习·ui·微信小程序·小程序·uni-app·编程
demi_meng3 小时前
reactNative 遇到的问题记录
javascript·react native·react.js
MC丶科4 小时前
【SpringBoot 快速上手实战系列】5 分钟用 Spring Boot 搭建一个用户管理系统(含前后端分离)!新手也能一次跑通!
java·vue.js·spring boot·后端
千码君20164 小时前
React Native:从react的解构看编程众多语言中的解构
java·javascript·python·react native·react.js·解包·解构
lijun_xiao20096 小时前
前端最新Vue2+Vue3基础入门到实战项目全套教程
前端
90后的晨仔6 小时前
Pinia 状态管理原理与实战全解析
前端·vue.js
杰克尼6 小时前
JavaWeb_p165部门管理
java·开发语言·前端
EndingCoder6 小时前
WebSocket实时通信:Socket.io
服务器·javascript·网络·websocket·网络协议·node.js
90后的晨仔6 小时前
Vue3 状态管理完全指南:从响应式 API 到 Pinia
前端·vue.js
90后的晨仔6 小时前
Vue 内置组件全解析:提升开发效率的五大神器
前端·vue.js