-
浅拷贝:
- 浅拷贝创建一个新的对象或数组,并复制原始对象的引用给新对象。
- 新对象和原对象共享相同的内存地址,修改其中一个对象会影响到另一个对象。
- 浅拷贝只复制一层对象的属性,对于嵌套对象或数组,仍然是引用关系。
-
深拷贝:
- 深拷贝创建一个全新的对象或数组,并递归地复制原始对象的所有属性和嵌套对象。
- 新对象和原对象是完全独立的,具有不同的内存地址,彼此之间的修改互不影响。
- 深拷贝会复制所有层级的对象及其属性,确保每个对象都是独立的副本。
在实际开发中,深拷贝通常比浅拷贝更安全,因为它能够保证独立性,避免了对象之间的意外修改。然而,深拷贝可能会占用更多的内存和处理时间,尤其是对于复杂的嵌套结构,所以在性能要求较高的场景下,需要权衡使用深拷贝的成本和收益。
在 JavaScript 中,可以使用以下方法进行浅拷贝和深拷贝:
-
浅拷贝:
- 数组:
Array.slice()
,Array.concat()
, 展开运算符 (...
) - 对象:
Object.assign()
, 展开运算符 (...
)
- 数组:
-
深拷贝:
- 自定义递归函数
- 第三方库如 Lodash 的
cloneDeep()
方法等
需要根据具体的需求选择合适的拷贝方式,确保代码的正确性和预期行为。