web前端高级JavaScript - 数组和对象的浅克隆与深克隆

本文探讨了JavaScript中的浅克隆和深克隆概念,解释了它们的差异。浅克隆仅复制对象的第一层级,而深克隆则递归复制所有层级。文章列举了多种实现浅克隆和深克隆的方法,包括基于循环、展开运算符、Object.assign、forEach、map、slice等。还讨论了JSON.stringify和JSON.parse方法在深克隆中的局限性,以及如何自定义代码实现深克隆。
摘要由CSDN通过智能技术生成

浅克隆

浅克隆是指:只克隆数组/对象的第一层级内容(开辟新的堆内存),而第二层级及以上层级的内容则直接引用(使用原来第二层级及以上层级的堆内存)。如果对克隆后对象的二级或以上层级进行修改,那么克隆前对象的二级或以上层级也会跟着被修改。
例如:现有一个对象obj1对应堆内存地址0x000,obj1对象中还有个子对象obj1_1对应堆内存0x001,现在想对obj1对象进行浅克隆,则会创建一个新的对象obj2对应新的堆内存地址0x002,对于对象obj1中的基本类型数据则会直接拷贝到obj2中,而obj1中的引用类型也就是子对象obj1_1则会直接被新对象obj2引用,而不是创建新的堆内存。后面如果通过操作obj2对obj2中的子对象obj1_1进行更改,那么obj1中的obj1_1也会随着变化,因为它们用的是同一个堆内存。来看下面的图会更直观一些
在这里插入图片描述

实现浅克隆的几种方案

  • 对象的浅克隆方案一:基于循环实现
let obj1 = {
   
	python: "python",
	java: "java"
	fontend: {
   
		javascript: "javascript",
		html: "html"
	}
}
let obj2 = {
   };//创建一个新对象(开辟新的堆内存)
//把obj1中私有的key和Symbol类型的key存在数组中
let keys = [
	...Object.keys(obj1),//展开运算符
	...Object.getOwnPropertySymbols(obj1)
]
keys.forEach(key => {
   
	obj2[key] = obj1[key];
});
console.log(obj1 === obj2); //false
console.log(obj1.fontend === obj2.fontend);// true
  • 对象的浅克隆方案二: 展开运算符
let obj1 = {
   
	python: "python",
	java: "java"
	fontend: {
   
		javascript: "javascript",
		html: "html"
	}
}
let obj2 = {
   
	...obj1
};
console.log(obj1 === obj2); //false
console.log(obj1.fontend === obj2.fontend);// true
  • 对象的浅克隆方案三:基于Object.assign()函数

Object.assign([obj1], …[obj2]):该方法接收多个参数,执行后会将obj2中的键值对合并到obj1中,并将obj1的堆内存地址返回。注意:这里返回的不是新的对象,而是把第一个参数作为返回值返回。
所以我们可以利用这个特点进行对象的浅克隆

let obj1 = {
   
	python: "python",
	java: "java"
	fontend: {
   
		javascript
  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值