2、对象拷贝(浅拷贝、深拷贝)、深拷贝的两种方法(递归、转JSON)

1、为什么要对象拷贝?

  • 对象作为函数参数的时候,返回一个全新的对象,不希望操作原对象,就时候就需要对象拷贝,也叫对象克隆

2、浅拷贝

  • 只能拷贝第一层级的。深层的不能拷贝(就是里面属性也是一个对象),拷贝的属性仍然是指向同一个对象,数据改变时也会影响到原始对象的数据
		// 对象拷贝(克隆):对象作为函数参数的时候,不希望操作原对象
		let stu = { name: "jasmine", age: 18, friend: { name: "qiqi" } };

		// 浅拷贝:只能拷贝第一层级的
		// 深层的不能拷贝(就是属性值也是一个对象),仍然是指向同一个对象
		function copyObject(obj) {
			let newObj = {};
			for (let i in obj) {
				newObj[i] = obj[i];
			}
			return newObj;
		}
		let newStu = copyObject(stu);
		newStu.age = 20;
		newStu.friend.name = "jasmine";
		console.log(stu);
		console.log(newStu);
		/*
		输出结果:
		stu = { name: "jasmine", age: 18, friend: { name: "jasmine" } };
		newStu = { name: "jasmine", age: 20, friend: { name: "jasmine" } };
		*/

3、深拷贝

  • 所有的层级的数据都拷贝过来,不放过一个属性,拷贝指向的对象都是一个全新的对象,不影响原始对象的数据
// 深拷贝:所有的层级的数据都拷贝过来,不放过一个属性
		function copyObject(obj) {
			let newObj = {};
			for (let i in obj) {
				// 递归(实现深度拷贝)
				if (obj[i] instanceof Object) {
					newObj[i] = copyObject(obj[i]);
				} else {
					newObj[i] = obj[i];
				}

			}
			return newObj;
		}
		let newStu = copyObject(stu);
		newStu.name = "qiqi";
		newStu.friend.name = "qiqi";
		console.log(stu);
		console.log(newStu);
		/*
		输出结果:
		stu = { name: "jasmine", age: 18, friend: { name: "jasmine" } };
		newStu = { name: "jasmine", age: 20, friend: { name: "qiqi" } };
		*/

4、浅拷贝与深拷贝的区别

类型区别
浅拷贝只拷贝第一层级的数据,深层的属性对象仍然指向同一个对象,数据改变时影响原始对象
深拷贝所有层级的数据都拷贝过来,数据改变时,不影响原始对象

4、深拷贝的两种方法(递归、转JSON)

<script>
		// 对象拷贝(克隆):对象作为函数参数的时候,不希望操作原对象
		var stu = { name: "jasmine", age: 18, friend: { name: "jasmine" } };

		// 深拷贝:所有的层级的数据都拷贝过来,不放过一个属性
		function copyObject(obj) {
			let newObj = {};
			// 1、递归(实现深度拷贝)
			for (let i in obj) {
				if (obj[i] instanceof Object) {
					newObj[i] = copyObject(obj[i]);
				} else {
					newObj[i] = obj[i];
				}
			}
			// 2、转JSON
			let newStr = JSON.stringify(obj);
			newObj = JSON.parse(newStr);
			return newObj;
		}
		var newStu = copyObject(stu);
		newStu.name = "qiqi";
		newStu.friend.name = "qiqi";
		console.log(stu);
		console.log(newStu);
		/*
		输出结果:
		stu = { name: "jasmine", age: 18, friend: { name: "jasmine" } };
		newStu = { name: "jasmine", age: 20, friend: { name: "qiqi" } };
		*/


	</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jasmine_qiqi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值