js深拷贝与浅拷贝

1 基础知识:基本类型与引用类型

 JS中可以把变量分成两部分,基本类型和引用类型。

 基本类型包括:Undefined、Null、Boolean、Number和String;
 引用类型值可能由多个值构成的对象。

在对基础类型数据进行拷贝时,实际相当于创建新的相同数据'hello',赋值给b

var a='hello';
var b = a;
b = 'world';
console.log(a);//"hello"

在对引用类型数据进行拷贝时,操作的不是实际的对象而是对象的引用,通过指针指向相同的内存区域,所以值相等;
在下面的代码中,因为arr和arr1指向同一内存区域,所以当改变arr1的值时,arr也跟着改变了

var arr = ['1','2'];
var arr1 = arr;
arr1[0] = '11';
console.log(arr); //["11", "2"]

2 浅拷贝

当我们在对引用类型数据进行拷贝时,就会产生类似上面子对象数据改变引起父对象数据同时改变的情况,这种拷贝就叫浅拷贝。

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

var xiaoming = {hobby:['唱歌','书法']};
var xiaoli = shallowCopy(xiaoming);

//如果将拷贝后的对象xiaoli的爱好更改,原对象xiaoming就也被更改了
// 因为xiaoli的hobby属性是个数组,即引用类型的数据,所以复制到的内容只是一个内存地址,并不是创建的新内容,详情请参考js的基本类型和引用类型
xiaoli.hobby[0] = '画画';
console.log(xiaoming);//{hobby: ["画画", "书法"]} 小明的内容也别改变了

3深拷贝

实现深拷贝的方法就是将浅拷贝递归,让每一次赋值都通过基础类型的创建新数据的赋值方式进行赋值

function deepCopy(src,dst){
  var dst =  dst || {};
  for (var i in src) {
    if (typeof src[i] === 'object') {
      dst[i] = (src[i].constructor === Array) ? [] : {};
      deepCopy(src[i],dst[i]);
    }else{
      dst[i] = src[i];
    }
  }
  return dst;
}

var xiaoming2 = {hobby:['唱歌','书法']};
var xiaoli2 = deepCopy(xiaoming2);
xiaoli2.hobby[0] = '画画';
console.log(xiaoming2);//{hobby: ["唱歌", "书法"]} xiaoming的内容不变   

4 代码地址 :http://jsbin.com/namajic/edit?js,console,output

 

转载于:https://www.cnblogs.com/houxiaohang/p/7463389.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值