深拷贝与浅拷贝的区别?

如何区分深拷贝与浅拷贝,简单点来说,就是假设B复制了A,当修改A时,看B是否会发生变化,如果B也跟着变了,说明这是浅拷贝;如果B没变,那就是深拷贝,自食其力。

//Shallow chone
let a=[0,1,2,3,4],
    b=a;
console.log(a===b);
a[0]=1;
console.log(a,b);
//deep clone
function deepClone(obj){
    
    
    //isArray() 用于确定传递的值是否是一个 Array
        let objClone = Array.isArray(obj)?[]:{
    
    }; 
        if(obj && typeof obj==="object"){
    
    
            for(key in obj){
    
    
                if(obj.hasOwnProperty(key)){
    
    
                    //判断ojb子元素是否为对象,如果是,递归复制
                    //hasOwnProperty() 方法会返回一个布尔值,指示对象自身属性中是否具有指定的属性
                    if(obj[key]&&typeof obj[key] ==="object"){
    
    
                        objClone[key] = deepClone(obj[key]);
                    }else{
    
    
                        //如果不是,简单复制
                        objClone[key] = obj[key];
                    }
                }
            }
        }
        return objClone;
    }    
    let a=[1,2,3,4],
        b=deepClone(a);
    a[0]=2;
    console.log(a,b);

猜你喜欢

转载自blog.csdn.net/qq_42526440/article/details/114649267