1、浅拷贝就是值的复制。对象因为是引用类型,所以它的值就是一个指针。当改变其中一个的时候,另一个也会改变。如下obj把它的指针复制给obj1 ,所以这两个对象指向同一个内存地址。当改变obj1的a属性后,obj的属性a也会发生变化。这就是浅拷贝。
let obj1 = {a:1};
let obj2 = {b:2};
obj2.__proto__ = obj1;
let obj3 = {...obj2};
console.log(obj3); //{b:2}
2、被拷贝的对象的第一层属性的属性值被改变不会影响到原对象,而第二层对象的属性值被改变会影响到原对象的属性值。意思是第一层是深拷贝第二层是浅拷贝。
第一层和第二层不一样是因为他们的类型不同,第一层是变量,它是简单数据类型,第二层是对象,是复杂数据类型,所以在第二层拷贝的时候,拷贝的是地址,所以会跟着发生变化,而第一层是变量,又重新开了一个空间,所以后面的改变不会影响前面的。
//深浅拷贝
const obj1 = {
a:1,
b:2,
d:{
aa:11,
bb:22
}
};
const obj2 = {
c:3,
d:9
};
const cObj1 = {...obj1};
console.log(obj1.a); //1
cObj1.a = 0;
//相互改变的只有引用类型,所以改变cObj1中的a属性,obj1中的是不会改变的
console.log(obj1.a); //1
//如果是直接赋值则会改变a的值,例如:
const cObj1 = obj1;