深拷贝是创建完全独立的新对象,避免引用类型数据相互影响;因对象数组为引用类型,浅拷贝仅复制地址会导致原对象被意外修改;常用方法包括JSON法(限纯JSON)、structuredClone(推荐现代环境)、手写递归(可定制)和Lodash cloneDeep(全面稳定)。
JavaScript 中的深拷贝,是指创建一个全新对象,其内部所有嵌套的对象、数组等引用类型数据也都被递归复制,新对象与原对象完全独立,互不影响。
因为 JavaScript 中对象和数组是引用类型。直接赋值(浅拷贝)只是复制了引用地址,修改新对象里的嵌套内容,原对象也会跟着变:
let obj1 = { a: 1, b: { c: 2 } };
let obj2 = obj1; // 浅拷贝(其实是引用)
obj2.b.c = 99;
console.log(obj1.b.c); // 输出 99 —— 被意外改了
没有一种方法完美适用于所有情况,需根据数据结构、是否含特殊值(如函数、undefined、Date、RegExp、Map、Set 等)来选择:
兼容老环境的项目。供理解原理,生产环境建议用 structuredClone 或 Lodash:
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;
}