JS关于Object.assign()和浅拷贝、深拷贝

什么是浅拷贝和深拷贝

  • js中存对象都是存地址的,浅拷贝指向的是同一块内存区块,深拷贝则是另外开辟了一块区域。

两个例子

var obj1 = { num: 100, str: 'abc' }
var obj2 = obj1
obj2.num = 200
console.log(obj1, obj2)  
打印结果:两个对象数据内容相同,因为是浅拷贝,两个对象指向同一内存区域
var obj1 = { num: 100, str: 'abc' }
var obj2 = deepCopy(obj1)
obj2.num = 200
console.log(obj1, obj2)
打印结果:两个对象数据内容不相同,num分别是100,200,这是深拷贝,两个对象指向内存地址不同

Object.assign()

  • 对象的静态方法,可以复制对象的可枚举属性到目标对象,实现对象属性的合并
var obj1 = {
    name: 'Jack',
    age: 31,
}
var obj2 = Object.assign(obj1, { age: 21, sex: 1 })
console.log(obj1)  // name: 'Jack', age: 21, sex: 1
  • 相同的属性,目标对象会被源对象覆盖。多个源对象时,存在相同属性,后面源对象覆盖前面的源对象
  • Object.assign()只是比浅拷贝多一层深拷贝而已,只能对单层的对象进行深拷贝,也就是对象里面的属性都是基本类型,没有嵌套
var obj2 = Object.assign({}, obj1)
如果obj1中都是基本类型则可以实现深拷贝
如果里面有Object类型,则obj2、obj1中的Object属性会一同变化
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值