js中浅拷贝和深拷贝的区别

浅拷贝与深拷贝的定义

浅拷贝只复制对象的第一层属性,如果属性是引用类型(如对象、数组),拷贝的是引用地址而非实际值。深拷贝会递归复制所有层级的属性,生成一个完全独立的新对象。

浅拷贝的实现方式

Object.assign()
适用于对象的第一层属性为基本类型的情况:

const obj = { a: 1, b: { c: 2 } };
const shallowCopy = Object.assign({}, obj);

扩展运算符
同理适用于简单对象:

const arr = [1, 2, { d: 3 }];
const shallowArr = [...arr];

深拷贝的实现方式

JSON.parse(JSON.stringify())
局限性:无法处理函数、undefined、循环引用等。

const obj = { a: 1, b: { c: 2 } };
const deepCopy = JSON.parse(JSON.stringify(obj));

递归实现
完整处理各种数据类型和循环引用:

function deepClone(target, map = new WeakMap()) {
    if (typeof target !== 'object' || target === null) return target;
    if (map.has(target)) return map.get(target);

    const clone = Array.isArray(target) ? [] : {};
    map.set(target, clone);
    for (const key in target) {
        clone[key] = deepClone(target[key], map);
    }
    return clone;
}

核心区别场景

修改嵌套属性时
浅拷贝的嵌套对象会互相影响:

const original = { x: { y: 10 } };
const shallow = { ...original };
shallow.x.y = 20;
console.log(original.x.y); // 输出 20

深拷贝的嵌套对象完全独立:

const original = { x: { y: 10 } };
const deep = deepClone(original);
deep.x.y = 20;
console.log(original.x.y); // 输出 10

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值