Javascript实现深拷贝的方法

浅拷贝

要想理解深拷贝,我们先来看一下浅拷贝,废话不多说,直接上代码

var obj = { a:1, arr: [2,3] };
var shallowObj = shallowCopy(obj);

function shallowCopy(src) {
  var dst = {};
  for (var prop in src) {
    if (src.hasOwnProperty(prop)) {
      dst[prop] = src[prop];
    }
  }
  return dst;
}

看这个例子,我们把obj对象直接拷贝给了shallowObj,不过这样有什么问题呢,比如我们再给shallowObj增加一个属性name:

shallowObj.arr.push('qing');
console.log(shallowObj);
console.log(obj)

这里写图片描述

可以看到obj也随着发生了改变

因为浅复制只会将对象的各个属性进行依次复制,并不会进行递归复制,而 JavaScript 存储对象都是存地址的,所以浅复制会导致obj.arr 和 shallowObj.arr 指向同一块内存地址。

大概的示意图如下
这里写图片描述

深拷贝

  • 递归实现
var people = {
     name:'xxx',
        friends:['people1','people2','peopple3'],
        info:{
              phone:'133xxxxxxxx',
              age:'18',
              sex:'man'
        }   
}
function deepCopy(p, c) {
  var c = c || {};
    for (var i in p) {
      if (typeof p[i] === 'object') {
        c[i] = (p[i].constructor === Array) ? [] : {};
        deepCopy(p[i], c[i]);
      } else {
         c[i] = p[i];
      }
    }
    return c;
  }
var person = deepCopy(people);
  • JSON实现
var result = JSON.parse(JSON.stringify(people))

我们给两种方法得到的新对象增加方法

person.friends.push('qing');
result.friends.push('Leon');

可以看到结果如下
这里写图片描述
所以原对象不会随着深拷贝过的对象而改变,深拷贝不仅将原对象的各个属性逐个复制出去,而且将原对象各个属性所包含的对象也依次采用深复制的方法递归复制到新对象上

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值