Javascript中的assign()方法到底是浅拷贝还是深拷贝?

针对于第一级拷贝是深拷贝,对于第二级拷贝是浅拷贝。
看代码:

let A = {
    a: { aa: 10 },
    b: 11,
};

let B = {
    ...A,
    c: 111,
};

console.log(B);  // { a: { aa: 10 }, b: 11, c: 111 }
B.a.aa = '修改1'; 
B.b = '修改2';
console.log(B); //{ a: { aa: '修改1' }, b: '修改2', c: 111 }
console.log(A); //{ a: { aa: '修改1' }, b: 11 }

从上面代码可以看到,
当使用assign方法拷贝了对象A给B后,B对象的a属性是一个Object类型,b属性是一个number类型,分别对a属性和b属性进行了修改,发现A对象的a属性随之也发生了修改,但是b属性没有变化。

所以 使用assign方法拷贝对象时,
如果对象的属性不是引用类型(比如number、string等),那么修改新对象的该属性值,原对象的该属性不会受到影响;
如果对象的属性是引用类型(Object),那么修改新对象的属性值,原对象的该属性也会随之改变。
所以assign的拷贝是浅拷贝。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值