首页 > 编程语言 > 详细

JavaScript中的浅拷贝和深拷贝

时间:2017-10-25 15:48:42      阅读:194      评论:0      收藏:0      [点我收藏+]

浅拷贝:拷贝引用。

拷贝后的新对象和源对象都是指向同一个引用地址,因此彼此之间操作互相影响。

let a = {num:1};

let b = a;

console.log(a===b); //true

a.num = 2;

console.log(b.num);//2

深拷贝:拷贝数据

深拷贝后的新对象在对内存中重新分配内存空间,并把源对象的所有数据都进行新建拷贝,以拷贝出来的新对象的引用跟源对象的引用指向不是同一个地址。

手动复制:手动的把源对象的每个属性依次给新对象的每一个属性。

var one ={a::1,,b:2,c:3};

var two ={a:one,b:one.b,c:one.c};

one.a=10;

console.log(one.a);//10

console.log(two.a)//1

JavaScript中的浅拷贝和深拷贝

原文:http://www.cnblogs.com/langwo/p/7729204.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!