极简三分钟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 认门牌:安家即落户(必须初始化),门牌永不换(绑定地址),屋里随便改(属性可调)。"

相关推荐
程序员码歌5 分钟前
OpenSpec 到 Superpowers:AI 编码从说清到做对
android·前端·人工智能
爱编程的小新☆6 分钟前
LangGraph4j工作流框架
前端·数据库·ai·langchain·langgraph4j
@PHARAOH22 分钟前
HOW - 构建一个轻量前后端一体服务
前端·微服务·服务端
无限进步_33 分钟前
【C++】C++11的类功能增强与STL变化
java·前端·数据结构·c++·后端·算法
一只小小Java34 分钟前
Echarts单表多图实现
前端·javascript·echarts
跟着珅聪学java35 分钟前
Element UI 的 Tabs 标签页开发教程
javascript·vue.js·elementui
dunky43 分钟前
Spring AI 深度解析:把 LLM 抽象成 Spring Bean 的底层逻辑
前端
星栈1 小时前
Rust WASM 文件上传全链路:从浏览器到 S3,一个字节都不能少
前端·前端框架·开源
濮水大叔1 小时前
告别 Django Admin!这个 NodeJS 全栈框架让你在 DTO 中直接配置 Table/Form 渲染
前端·typescript·node.js
JarvanMo1 小时前
Flutter 3.44 & Dart 3.12重磅发布!这些新特性太香了
前端