JavaScript深拷贝需创建完全独立的新对象以避免引用共享,常用方法包括:JSON.parse(JSON.stringify())(简洁但类型支持有限)、structuredClone()(现代标准,支持多数复杂类型)、递归手写(可控性强,可定制)、Lodash的_.cloneDeep()(生产环境稳妥选择)。
JavaScript实现深拷贝的核心是创建一个与原对象完全独立的新对象,新对象的属性值(包括嵌套对象、数组等)不共享原对象的内存引用。直接赋值或浅拷贝(如 Object.assign()、展开运算符)只复制第一层引用,无法处理嵌套结构,因此不可靠。
这是最常用、写法最简洁的方法,适用于纯数据对象(仅含字符串、数字、布尔值、null、数组、普通对象):
TypeError: Converting circular structure to JSON)示例:const copy = JSON.parse(JSON.stringify(original));
浏览器和 Node.js(v17.0+,需启用 --experimental-structured-cloning;v18.12+ 默认支持)已原生支持 structuredClone():
示例:const copy = structuredClone(original);
适合需要兼容老环境、或需特殊逻辑(如忽略某些字段、转换特定类型、处理自定义类)的场景。关键点包括:
Array.isArray() 判断数组,避免用 typeof
Object.prototype.toString.call() 或 constructor 辨别 Date、RegExp 等内置对象简易版(不含循环引用处理):function deepClone(obj) {
if (obj === null || typeof obj !== 'object') return obj;
if (obj instanceof Date) return new Date(obj);
if (obj instanceof RegExp) return new RegExp(obj);
const cloned = Array.isArray(obj) ? [] : {};
for (let key in obj) {
if (obj.hasOwnProperty(key)) {
cloned[key] = deepClone(obj[key]);
}
}
return cloned;
}
如果项目已引入 Lodash,_.cloneDeep() 是经过大量测试、覆盖边缘情况的成熟方案:
示例:import { cloneDeep } from 'lodash-es';
const copy =
cloneDeep(original);