javascript - js替换和添加对象成员的效率是一样的吗?

查看:73
本文介绍了javascript - js替换和添加对象成员的效率是一样的吗?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

如题,比如有这么两个例子(大家可以自行想象其它例子):

// 替换的例子
let a = {'a': 123, 'b': 234, 'c': 345}
let tmp = {'a': 'qwe'}
a = {...a, tmp}

// 删除再添加的例子
let a = {'a': 123, 'b': 234, 'c': 345}
let tmp = {'a': 'qwe'}
delete a.a
a = {...a, tmp}

请问谁的效率要高些?

解决方案

delete 慢也就不说了,关键是它还不会直接释放内存(MDN 文档一开始就提到了这点)。所以你的情况直接替换,不用想太多。

那么 delete 有啥用呢?

目前我能想到的,就是在继承的情况下可用。比如某个对象的原型链上有属性 a,它自己也定义了属性 a,然后由于某些原因不再需要它自身的属性 a,只需要使用原型链上的……那就把自己这个属性删掉。但即使这应用,也是很难碰到实际应用场景的。

这篇关于javascript - js替换和添加对象成员的效率是一样的吗?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆