【JS基础】深拷贝、浅拷贝

浅拷贝

  • 会创建一个新的对象
  • 只会复制对象的属性
  • 如果该对象中有其他引用值,会复制该引用值的引用地址。
Object.prototype.num = 1;
var person1 = {
	name:'张三',
	age:18,
	height:180,
	weight:140,
}
//拷贝方法
function clone(origin,target){
	var tar =target || {};
	for(var key in origin){
		if(origin.hasOwnProperty(key)){
			tar[key] = origin[key];
		}
	}
	return tar;
}
//创建新的对象,将person1中的属性复制到person2中
var person2 = clone(person1);
//修改person2中的属性,person1中的属性不会修改
person2.name = '李四';
console.log(person1,person2);

在这里插入图片描述

Object.prototype.num = 1;
var person1={
	name:'张三',
	age:18,
	height:180,
	weight:140,
	children:{
		first:{
			name:'张一',
			age:13
		}
	}
}
//拷贝方法
function clone(origin,target){
	var tar =target || {};
	for(var key in origin){
		if(origin.hasOwnProperty(key)){
			tar[key] = origin[key];
		}
	}
	return tar;
}
//创建新的对象,将person1中的属性复制到person2中
var person2 = clone(person1);
//修改person2中的属性,person1中的属性不会修改
person2.name = '李四';
//修改person2中的引用值后,person1和person2中相应的值都会修改。因为这里复制的引用值的地址
person2.children.first.name='李三'
console.log(person1,person2);

在这里插入图片描述

深拷贝

  • 创建一个新的对象
  • 复制对象的属性
  • 如果该对象中有其他引用值,会依次复制引用值的属性
Object.prototype.num = 1;
var person1={
	name:'张三',
	age:18,
	height:180,
	weight:140,
	children:{
		first:{
			name:'张一',
			age:13
		},
		second:{
			name:'张二',
			age:13
		},
		third:{
			name:'张四',
			age:13
		},
		car:['Benz','Mazda']
	}
}
//深拷贝
function deepClone(origin,target){
	var target = target || {};
		toStr = Object.prototype.toString,
		arrType='[object Array]';
	for(var key in origin){
		if(origin.hasOwnProperty(key)){
			//判断是不是对象或者时null,如果不是直接复制
			if(typeof(origin[key])=='object' && origin[key] !== null){
				//如果时对象,判断是数组或这对象。并创建 
				if(toStr.call(origin[key])===arrType){
					target[key] = [];
				}else{
					target[key] = {};
				}
				//递归该子对象
				deepClone(origin[key],target[key]);
			}else{
				target[key] = origin[key];
			}
		}
	}
	return target;
}
var person2=deepClone(person1);
person2.children.first.name = '李四'
console.log(person1,person2);

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值