JavaScript 深拷贝

为什么会有深拷贝

拷贝一词最早是在学习C++时听到的。在JavaScript中有三种引用值:Array、Object、Function。
引用值在赋值时传递的是地址。若不考虑这一点,单纯的直接“=”,就是我们所说的浅拷贝。拷贝过后,对引用类型数据的修改会影响到拷贝的对象和被拷贝的对象。深拷贝就是在拷贝过程中若遇到了引用值就new 一块新空间来存放引用类型中的普通数据。

递归来实现深拷贝

现在想来,当初学习C++时只是理解了什么是深浅拷贝,如何实现缺没有实践。遗憾遗憾
原理很简单:
遍历要拷贝的目标对象:对于普通属性之间赋值。对于数组或者对象,则新建一个数组或对象,再遍历该数组或对象重复上述步骤即可。

	<script type="text/javascript">
		function deepClone(origin, target){
			var target = target || {};   //当没有传入target对象时,生成一个空对象
			for(var prop in origin){
				if(origin.hasOwnProperty(prop)){   //拷贝自己的属性
					if(origin[prop] !== "null" && typeof(origin[prop]) == "object"){   //typeof(null) 返回值为“object”  .咋也不知道
						target[prop] = Object.prototype.toString.call(origin[prop]) == "[object Array]" ? [] : {};
						deepClone(origin[prop], target[prop]);   //递归直到不含引用值为止
					}else{   
						target[prop] = origin[prop];
					}
				}
			}
			return target;
		}

		var origin = {
			a : "123",
			b : [1,2,3],
			c : {
				d : 1,
				f : 2
			}
		}
		var copy = deepClone(origin);
		copy.b.push(4,5,6);
		copy.c.g = 3;
		console.log(copy);
		console.log(origin);
	</script>

在这里插入图片描述
可以看到对copy的修改不会影响到origin

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值