深拷贝和浅拷贝

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;
            

 





posted @ 2020-06-25 23:08  是桂  阅读(233)  评论(0)    收藏  举报