对象的冻结

const声明常量并不会真的不能改变,只是const变量后保存的那个值不会改变, 如果那个值是地址值的话, 只能保证地址值不会改变, 但是地址值指向的对象内部的改变, const表示它管不着。

对于对象,可以使用冻结的方法使它无法被改变

<script>
    var a = {
        name: 'sas',
        b: {
            nob: 13
        }
    }
    // Object.freeze(a)
    a.name = 'aaa'
    // 冻结后修改对象的属性并没有作用
    console.log(a.name)
    a.b.nob = 14
    // 但是只能冻结表层, 如果属性还是一个对象的话,并没有冻结
    console.log(a.b.nob)

    function freeObj(obj) {
        Object.freeze(obj)
        Object.keys(obj).forEach(o => {
            // type of对象是小写的object字符串
            if(typeof obj[o] == 'object'){
                freeObj(obj[o])
            }
        })
    }
    freeObj(a)
    a.b.nob = 15
    // 并没有被修改,说明全部被冻结
    console.log(a.b.nob)
</script>
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值