极简三分钟ES6 - const声明

基础特性

声明时必须赋值 const 声明的变量必须在定义时初始化,否则报错

js 复制代码
const PI; // 报错!未初始化
const PI = 3.14; // 正确 

这一点与 letvar 不同(它们可以先声明后赋值)

变量名绑定不可变(基本类型)

const 声明基本类型(数字、字符串、布尔值)时,值不可修改

js 复制代码
const MAX = 100;
MAX = 200; // 报错!常量值不可变

如果强行修改,浏览器会直接抛出错误

引用类型的特殊行为

常量指向的地址不变,但属性可修改

const 声明对象或数组时,变量保存的是内存地址(类似门牌号)。

  • 门牌号不可变 → ❌ 不能重新赋值整个对象
  • 屋内的家具可调整 → ✅ 可修改对象属性或数组元素
js 复制代码
const person = { name: "小明" };
person.name  = "小红"; // 允许!修改属性
person = { age: 18 }; // 报错!禁止更换对象 

彻底冻结对象的方法 若需完全禁止修改对象,可使用 Object.freeze()

js 复制代码
const obj = Object.freeze({  key: "值" });
obj.key  = "新值"; // 修改无效(严格模式下报错)

注意:freeze 只能冻结第一层属性,嵌套对象仍需递归处理

其他规则

块级作用域

let 一致,const 只在 {} 内有效

js 复制代码
if (true) {
  const x = 10;
}
console.log(x);  // 报错!x 未定义 

禁止重复声明 & 存在暂时性死区(TDZ)

  • 同作用域内不可重复声明:const a=1; const a=2; // 报错
  • 声明前访问会触发死区报错
js 复制代码
console.log(a);  // 报错!死区限制
const a = 5;

对比 const vs let vs var

特性 const let var
作用域 块级作用域 块级作用域 函数/全局作用域
重复声明 ❌ 禁止 ❌ 禁止 ✅ 允许
声明时初始化 ✅ 必须 ❌ 可选 ❌ 可选
值可变性 ❌ 基本类型不可变 ✅ 引用属性可修改 ✅ 可随意修改 ✅ 可随意修改

何时用 const

  • 声明后永不改变的标识符(如数学常数、配置项)
  • 引用类型数据(如对象、数组)需保持引用不变时
  • 替代 var 避免意外覆盖

牢记

"const 认门牌:安家即落户(必须初始化),门牌永不换(绑定地址),屋里随便改(属性可调)。"

相关推荐
Championship.23.241 小时前
Open Source Pipeline Skill深度解析:自动化开源贡献全流程
前端·javascript·html
Bigger1 小时前
🧠 前端岗位的"结构性调整":现象背后的冷思考
前端·程序员·ai编程
薯老板1 小时前
vue组件之间的通信
前端·vue.js
迪菲赫尔曼1 小时前
从 0 到 1 打造工业级推理控制台:UltraConsole(Ultralytics + FastAPI + React)开源啦!
前端·yolo·react.js·计算机视觉·开源·fastapi
万邦科技Lafite1 小时前
京东开放API接口:item_get返回参数指南
java·前端·javascript·api·电商开放平台
梦想CAD控件1 小时前
网页CAD协同设计平台-生产级在线实时协同CAD引擎
前端·javascript·架构
Highcharts.js1 小时前
React 开发实战:如何使用 useEffect 为 Highcharts 注入实时数据
前端·javascript·react.js·开发实战·实时数据·highcharts·轮询数据
陆枫Larry1 小时前
Vue Slot 到底在解决什么问题?
前端
梦想很大很大1 小时前
让 AI 成为“报表配置员”:BI 低代码平台的 Schema 实践路径
前端·人工智能·低代码
用户059540174461 小时前
asyncio 踩坑实录:这个问题坑了我3小时,差点让线上服务崩掉
前端·css