javascript“常量”对象(深度冻结)
先看下面一段代码:
const obj = {
m: 2
}
console.log(obj.m); //2
obj.m = 3;
console.log(obj.m); //3
我们发现虽然obj对象我们定义的是一个常量,但是仍然可以修改里面m的值,这是因为const保证的并不是obj的值不变,而是obj指向的内存地址不变,我们修改m的值的时候obj的内存地址并没有改变。
那为什么简单数据类型就是变量的值不变呢?
那是因为对于简单数据类型,值就保存在变量指向的内存地址中,如果改变变量的值就等同于给变量换了一块内存地址,const定义的数据是不允许的。
那我们如何像简单数据类型一样保证对象的所有内容一直不变呢?
那我们需要永久冻结此对象。
先看下面一段代码:
//永久冻结方法(有一点错误)
function constantize(obj){
Object.freeze(obj);

本文探讨了JavaScript中如何确保对象常量不变性。通过举例说明const关键字并不能阻止对象内部属性的修改,然后提出了深度冻结对象的方法,但遇到了Object.keys()无法处理非枚举属性的问题。最后,通过使用Object.getOwnPropertyNames()解决了这一问题,实现了对象的深度冻结,确保其内容不可变。
最低0.47元/天 解锁文章
51

被折叠的 条评论
为什么被折叠?



