手写实现浅拷贝与深拷贝
时间: 2024-06-12 13:11:21 浏览: 169
浅拷贝和深拷贝都是对象的复制方式,浅拷贝只是复制了对象的引用,而深拷贝则是复制了对象的值。下面是手写实现浅拷贝和深拷贝的方法:
浅拷贝:
1.使用Object.assign()方法,将源对象的属性复制到目标对象中。
2.使用展开运算符(...),将源对象的属性展开到目标对象中。
深拷贝:
1.使用JSON.parse(JSON.stringify(obj))方法,将对象转换为JSON字符串再转换为对象,将需要克隆对象的属性执行深拷贝后依次添加到新对象上。同时,为了解决循环引用问题,可以额外开辟一个存储空间,来存储当前对象和拷贝对象的对应关系,当需要拷贝当前对象时,先去存储空间中找,有没有拷贝过这个对象,如果有的话直接返回,如果没有的话继续拷贝。
相关问题
手写代码实现浅拷贝与深拷贝
浅拷贝是指将一个对象的属性值复制到另一个对象,如果属性值是基本类型,则直接复制,如果属性值是引用类型,则复制的是引用,两个对象会共享同一个引用类型的属性值。深拷贝是指将一个对象的所有属性值都复制到另一个对象,包括基本类型和引用类型,两个对象的属性值互不影响。
以下是JavaScript手写代码实现浅拷贝和深拷贝的示例:
// 浅拷贝
function shallowCopy(obj) {
if (typeof obj !== 'object' || obj === null) {
return obj;
}
const newObj = Array.isArray(obj) ? [] : {};
for (let key in obj) {
if (obj.hasOwnProperty(key)) {
newObj[key] = obj[key];
}
}
return newObj;
}
// 深拷贝
function deepCopy(obj) {
if (typeof obj !== 'object' || obj === null) {
return obj;
}
const newObj = Array.isArray(obj) ? [] : {};
for (let key in obj) {
if (obj.hasOwnProperty(key)) {
newObj[key] = deepCopy(obj[key]);
}
}
return newObj;
}
浅拷贝的实现方式是遍历对象的属性,将属性值复制到新的对象中。如果属性值是基本类型,则直接复制,如果属性值是引用类型,则复制的是引用,两个对象会共享同一个引用类型的属性值。
深拷贝的实现方式是遍历对象的属性,如果属性值是基本类型,则直接复制,如果属性值是引用类型,则递归调用深拷贝函数,将引用类型的属性值也进行深拷贝。这样可以保证两个对象的属性值互不影响。
js 手写深拷贝和浅拷贝
深拷贝和浅拷贝是 JavaScript 中用于复制对象的两种不同方式。
浅拷贝只是复制对象的第一层属性,而不会复制对象中的引用类型属性。也就是说,浅拷贝只会复制对象的引用,而不会创建一个新的对象。这意味着,如果原始对象中的引用类型属性发生变化,拷贝后的对象中的属性值也会随之改变。使用浅拷贝可以通过遍历对象中的属性,并将其复制到一个新对象中来实现。你可以使用循环、递归或者使用一些内置的方法来手写浅拷贝。举个例子,你可以通过遍历对象中的属性,并将其复制到一个新对象中来实现浅拷贝。比如使用递归的方式,你可以逐个复制对象中的属性到一个新的对象中,但是注意,只有第一层的属性会被复制到新对象中。
深拷贝则是复制对象的所有层次,包括对象的引用类型属性。这意味着,如果原始对象中的引用类型属性发生变化,拷贝后的对象中的属性值不会受影响。深拷贝会创建一个完全相同但是独立的对象。实现深拷贝可以使用递归的方式,对于对象的每一个属性,如果是引用类型,则递归调用深拷贝方法来复制属性值。你也可以使用一些内置的方法或者第三方库来实现深拷贝,比如使用 JSON.parse(JSON.stringify(object)) 来实现深拷贝。需要注意的是,使用这种方法时,对象中的函数、正则表达式以及 undefined 类型的属性会被忽略掉。
所以,通过手写深拷贝和浅拷贝,可以更好地理解递归、循环引用、weakMap、创建各种引用类型的方法、判断数据类型、箭头函数与普通函数的区别、正则表达式等知识。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [JavaScript基础:手写浅拷贝与深拷贝](https://blog.csdn.net/imagine_tion/article/details/115322522)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *2* *3* [JS 浅拷贝和深拷贝详解(巨详细)](https://blog.csdn.net/qq_63299825/article/details/131003216)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文