Object.freeze原来有这么大的作用

一、Object.freeze可以冻结一个对象,冻结指的是不能向这个对象添加新的属性,不能修改其已有属性的值,不能删除已有属性,以及不能修改该对象已有属性的可枚举性、可配置性、可写性。该方法返回被冻结的对象。
如果你有一个巨大的数组或Object,并且确信数据不会修改,使用Object.freeze()可以让性能大幅提升。这种提升大约有5~10倍,倍数随着数据量递增,对于纯展示的大数据,都可以使用Object.freeze提升性能。

具体方法

data(){
	return {
		list:Object.freeze([
			{id:1,name:'zs'},
			.....     //假设这里很多很多条数据
		]),
		list2:[{id:1,name:'zs'}]      //正常写法
		
	}
}

深度冻结
由于Object.frezze()只能浅度冻结

function deepFreeze(obj){
	for(key in obj){
		if(obj[key] instanceof Object){
			deepFreeze(obj[key])
		}
	}
	return Object.freeze(obj)
}
let person = { 
	name: '小明',
	age: 18,
	child:{ 
		name:'小黄',
		age: 2 
	} 
}
deepFreeze(person)
person.child.name = '小红'    
console.log(person)  //输出没变
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值