Object.freeze()方法

Object.freeze()

  • 渲染大量数据时应该怎么优化?
  • 这个方法是用来冻结对象的,调用这个方法的对象不能添加新的属性、方法
let obj = {
                name: '张三',
                age: 18,
            }
            Object.freeze(obj)
            obj.hobby = 'rap'
            console.log(obj)

  • 如上图,在冻结对象以后,使用点语法添加了新的属性hobby,但是我们打印出来会发现新增属性这一操作是无效的,因为对象已经被冻结了,在严格模式下,冻结之后使用点语法添加新属性控制台会报错。
  • 当然,这只是针对简单的对象来进行冻结,如果遇到了复杂的对象,对象的属性值又为对象这种情况,那么我们就要利用递归,来给对象及其为对象的子属性进行冻结:
    封装函数:
 // 深度冻结对象
            const freezeDeep = (obj) => {
                Object.freeze(obj)
                Object.keys(obj).forEach((key, i) => {
                    if (obj[key] instanceof Oject) {
                        freezeDeep(obj[key])
                    }
                })
            }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

短暂又灿烂的

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值