clone是深拷贝还是浅拷贝_理解JavaScript中的浅拷贝与深拷贝

620c2ea9ea137fbb4386cbbf7c9ce390.png

浅拷贝

在使用JavaScript对数组进行操作的时候,如果只是简单的将它赋予其他变量,那么我们只要更改其中的任何一个,然后其他的也会跟着改变,这就导致了问题的发生

var arr = ['aa','bb','cc'];var arr2 = arr;arr2[0] = '新来的';console.log(arr);//输出 '新来的','bb','cc'

由此可见对数组arr2进行修改时,而arr内数据也会随之改变。这种直接赋值的方式就是浅拷贝现象。那到底是为什么呢?

因为JavaScript存储对象都是存地址的,所以浅复制会导致 arr 和 arr2 指向同一块内存地址,大概的示意图如下。

cac8a23bc214a22a9e32294134b9a363.png

所以当修改arr2中的数据时,由于arr也指向此处,所以arr的数据也就被“修改了”。

深拷贝

一般都是开辟一块新的内存地址,将原对象的各个属性逐个复制出去。如下图所示

8fcfc1baa15b310f54d842aa63c92ea8.png

所以当修改arr2中的数据时,由于arr与arr2地址不同,所以arr的数据还是原来的。

数组的深拷贝

var arr = ['aa','bb','cc'];var arr2 = arr.slice(0);arr2[0] = "新来的";console.log(arr);//输出:数组的原始值:'aa','bb','cc'console.log(arr2);//输出:数组的新值:'新来的','bb','cc'

Json的深拷贝

在这里利用JSON下的两个方法来实现对象的深拷贝。

var json = {a:12,b:5};var str = JSON.stringify(json);//这里将json内的数据转换成一个字符串存起来var json2 = JSON.parse(str);//这里将字符串的内容"还原"成原来的"面目"console.log(json2);//输出 {a:12,b:5}

总结

其实在js中还有很多方法能进行深拷贝,例如利用数组下的cancat方法;对Json进行遍历然后给新的对象等等。

补充

以上只考虑了纯数组或者纯对象(json串)的情况,当互相嵌套时确实有问题,经过查阅资料找到了一个函数

function cloneObject( obj, deep ){  if ( obj === null || obj === undefined || typeof (obj) !== 'object' ){  return obj;  }  var deep = !!deep;  var cloned = null;  if ( obj.constructor === Array ){    if ( deep === false ) return obj;    cloned = [];    for ( var i in obj ){    cloned.push( cloneObject( obj[i], deep ) );    }    return cloned;  }  cloned = {};  for ( var i in obj ){  cloned[i] = deep ? cloneObject( obj[i], true ) : obj[i];  }  return cloned;}var arr = [1, 3, 5, {a: 5}]var newArr =cloneObject(arr,true);newArr[3].a = 9console.log(arr, newArr)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值