😁 作者简介:一名大三的学生,致力学习前端开发技术
⭐️个人主页:夜宵饽饽的主页
❔ 系列专栏:前端js专栏
👐学习格言:成功不是终点,失败也并非末日,最重要的是继续前进的勇气
🔥前言:
这是自己在学习JavaScript的学习笔记和总结,希望可以帮助到你
2.3 const 命令
2.3.1 基本用法
-
const 声明一个只读常量。一旦声明,常量的值就不能改变
const PI=3.1415; console.log(PI) //3.1415 PI=3; //TypeError:Assignment to constant variable
上面的代码表明改变常量的值会报错
-
const 声明的常量不得改变值,这意味着,const 一旦声明常量,就必须立即初始化,不能留到以后赋值
const a //SyntaxError:Missing initializer in const declaration
上面的代码表示,对于const 而言 只声明不赋值就会报错。
-
const 的作用域与let 命令相同:只在声明所在的块级作用域内有效
if(true){ const MAX=5 } MAX//Uncaught ReferenceError:MAX is not defined
-
const 命令声明的常量也不会提升,同样存在暂时性死区,只能在声明后使用
if(true){ console.log(MAX) //ReferenceError const MAX=5 }
-
使用const声明的变量也与let 一样,不可重复声明
2.3.2 本质
const 实际上保证并不是变量的值不得改动,而是变量指向得那个内存地址不得改动,对于简单类型的数据(数值,字符串,布尔值)而言,值就保存在变量指向的内存地址中,而复合类型(数组和对象)而言,变量指向的内存地址保存的只是一个指针,const只能保证这个指针是固定的。
const fpp={}
//为foo添加一个属性,可以成功
foo.prop=123
foo.prop //123
//将foo指向另一个对象,就会报错
foo={}//TypeError:'foo' is read-only
上述的代码中,常量foo储存的是一个地址,这个地址指向一个对象,不可变的只是这个地址,即不能把foo指向另一个地址,但对象本身是可变的,所以依然可以为其添加新属性
数组也是一样的
const a=[]
a.push('b');//可以执行
a.length=0;//可以执行
a=['c']//报错
上面的代码中,常量a是一个数组,这个数组本身是可写的,但是如果将另一个数组赋值给a就会报错
如果我们真的想把对象冻结,应该使用Object.freeze方法