javascript“常量”对象(深度冻结)

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

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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值