Js 对象的浅拷贝和深拷贝

一、以下的方式并不算浅拷贝

    var obj = {
        name: '张三',
        arr: [1,2,3]
    }

    function copy(obj){
        var Obj = obj;
        return Obj;
    }

    var obj1 = copy( obj );

    obj1.name = 'lisi';

    console.log( obj );    // name : 'lisi'
    console.log( copy( obj ) );   // name : 'lisi'

 上面的两个变量都是指向同一个地址。其实还是同一个对象。

 

二、浅拷贝

    var obj = {
        name: '张三',
        arr: [1,2,3]
    }

    function shadowCopy(obj1){

        var obj2 = {};

        for( var k in obj1 ){
            obj2[k] = obj1[k]; // 思路是把obj1的属性复制一份给obj2;
                               // 如果这个属性是对象的话,只是复制了指针.
                               // obj1.arr和obj2.arr都是只是同一个地址
        }

        return obj2;
        
    }

    var obj1 = shadowCopy( obj );

    obj1.name = 'lisi';
    obj.arr[0] = 111;

    console.log( obj );    // name : 'zhangsan', arr: [111,2,3]
    console.log( obj1 );   // name : 'lisi', arr: [111,2,3]

上面的思路,就是通过循环吧obj1的属性都复制给obj2;但是如果属性是对象或者是数组的话,属性的key指向的其实还是同一个对象。两个对象还有属性是共用内存的。这就是浅拷贝。

三、深拷贝(利用递归实现深拷贝)

    var obj = {
        name: '张三',
        arr: [1,2,3]
    }
    var Obj = {};

    function deepCopy(obj1, obj2){

        var obj2 = obj2 || {};
        
        for( var key in obj1 ){
            if( typeof obj1[key] == 'object' ){
                obj2[key] = ( obj1[key].constructor === Array ) ? [] : {};
                deepCopy( obj1[key], obj2[key]);
            } else{
                obj2[key] = obj1[key];
            }
        }
    
        return obj2;
        
    }

    var obj1 = deepCopy( obj, Obj );

    obj1.name = 'lisi';
    obj.arr[0] = 111;

    console.log( obj );    // name : 'zhangsan', arr: [1,2,3]
    console.log( obj1 );   // name : 'lisi', arr: [111,2,3]

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值