JS深拷贝和浅拷贝

 

  1. 浅拷贝只是拷贝一层,更深层次对象级别的只拷贝引用。
  2. 浅拷贝是拷贝的内存地址,使新对象指向拷贝对象的内存地址。深拷贝是重新开辟一块内存空间,用来存放sources对象的值。
  3. 浅拷贝可以用for in 来实现,也可用es6新增方法Object.assign(target,...sources) 来实现,target为目标对象,sources为原对象(要进行拷贝的对象)
  4. 浅拷贝后改变target中的值,sources也会进行改变。深拷贝不会这样
  5. 深拷贝可以基于函数封装的方法来进行实现。
<body>
    <script>
        var obj = {
            id: 1,
            name: 'andy',
            msg: {
                age: 18
            }
        };
        var o = {};
        var j = {};
        function shallowCopy(newobj, oldobj) {
            for(var k in oldobj){
                newobj[k] = old[k];
            }
        }
        shallowCopy(o, obj);
        console.log('o',o)
        o.id = 2;
        console.log('obj',obj)
        //封装深拷贝函数
        function deepCopy(newobj, oldobj) {
            for (var k in oldobj) {
                //判断属性值属于那种数据类型
                //1.获取属性值 old[k]
                var item = oldobj[k];
                //2. 判断这个值是否是数组
                //必须先判断是否是Array 因为Array 也是Object
                if(item instanceof Array){
                    newobj[k] = [];
                    deepCopy(newobj[k], item);
                }else if(item instanceof Object){
                    //3.判断这个值是否是对象
                    newobj[k] = {};
                    deepCopy(newobj[k], item);
                } else {
                    //4.属于简单数据类型
                    newobj[k] = item;
                }
            }
        }
        deepCopy(j,obj);
        console.log('j',j);
        j.id = 4;
        console.log('obj',obj);
    </script>
</body>

存在不足之处可随时补充。

学习地址

  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值