Object.assign()方法是浅拷贝吗

是的,Object.assign() 方法是一种浅拷贝方法。也就是说,它只会复制对象的第一层属性,而不会复制对象内部的所有嵌套属性。

具体来说,Object.assign() 方法会将目标对象的属性替换为源对象的属性,如果目标对象和源对象都有同名的属性,则会覆盖目标对象的属性。如果源对象有多个属性,则这些属性会按照顺序依次复制到目标对象中。例如:

 

javascriptCopy Code

const targetObj = { a: 1 }; const sourceObj = { b: 2, c: 3 }; const result = Object.assign(targetObj, sourceObj); console.log(targetObj); // {a: 1, b: 2, c: 3} console.log(result); // {a: 1, b: 2, c: 3}

在上面的例子中,我们使用 Object.assign() 方法将 targetObjsourceObj 合并,得到了一个新对象 result。可以看到,Object.assign() 方法只复制了源对象的属性,没有复制源对象中的嵌套属性。

需要注意的是,如果源对象的属性值是对象或数组等引用类型数据,那么只会复制对象或数组的地址,并没有真正地复制该对象或数组。因此,在修改复制后的对象时,可能会影响到源对象和其他目标对象。例如:

 

javascriptCopy Code

const targetObj = { a: {} }; const sourceObj = { b: {} }; Object.assign(targetObj, sourceObj); console.log(targetObj); // {a: {}, b: {}} console.log(targetObj.a === sourceObj.b); // true 赋值的是同一对象,地址相同

在上面的例子中,我们可以看到,Object.assign() 方法只是将源对象中的对象地址复制到了目标对象中,因此 targetObja 属性与 sourceObjb 属性引用的是同一个对象。因此,在修改 targetObj.a 的同时,也会影响到 sourceObj.b

总之,Object.assign() 方法是一种浅拷贝方法,只会复制对象的第一层属性,并且在复制引用类型数据时只会复制地址而不是真正的对象或数组。需要开发者根据自己的需求谨慎使用。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值