JS定义const常量对象

本文探讨了ES6中的const关键字,指出它仅防止变量标识符的重新赋值,而不阻止对象属性的修改。通过示例展示了即使使用const声明,对象和数组的属性和元素仍可更改。为了创建真正的常量对象,需要借助Object.freeze方法来冻结对象,使其不可扩展、不可删除、不可修改。最后,文章提到了Object.isFrozen方法用于检查对象是否已被冻结。
摘要由CSDN通过智能技术生成

ES6中新增const关键字,用于声明创建一个只读引用。

但其只是规定变量的标识符不能重新分配,例如声明变量是引用类型,则不可变的只是变量绑定的指针(JS不存在这个概念,指变量的值是栈中存放的内存地址,访问时会自动寻址找到堆中存放的对象),而对象的属性可以任意改变。

const o = {
	a: 1
}

const a = [2, 3, 4]


o.b = 2 // 可扩展

o.c = 4

delete o.c // 可删除

o.a = 3 // 可修改

 
a.push(5) // 可扩展

a.pop() // 可删除

a[0] = 3 // 可修改

 
console.log(o) // {a: 3, b: 2}

console.log(a) // [3, 3, 5]

所以const关键字并不能定义真正的常量对象,真正的常量对象应该是:不可扩展、不可删除、不可修改的。

要做到这些,我们需要一个函数的帮助。

实现常量对象

Object.freeze方法可以冻结一个对象,冻结表示该对象不可扩展、不可删除、不可修改,并且不能修改该对象已有属性的可枚举性、可配置性、可写性。该方法修改原对象,并返回该对象。(0 0 0)

Object.isFrozen(obj)返回obj是否被冻结。

const o = { a:1 }

Object.freeze(o)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值