当前位置:   article > 正文

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

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/68205
推荐阅读
相关标签
  

闽ICP备14008679号