赞
踩
是的,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()
方法将 targetObj
和 sourceObj
合并,得到了一个新对象 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()
方法只是将源对象中的对象地址复制到了目标对象中,因此 targetObj
的 a
属性与 sourceObj
的 b
属性引用的是同一个对象。因此,在修改 targetObj.a
的同时,也会影响到 sourceObj.b
。
总之,Object.assign()
方法是一种浅拷贝方法,只会复制对象的第一层属性,并且在复制引用类型数据时只会复制地址而不是真正的对象或数组。需要开发者根据自己的需求谨慎使用。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。