JS中用遍历对象的办法实现对象深拷贝的原理
时间: 2023-10-12 11:20:20 浏览: 102
对象深拷贝是指创建一个新的对象,该对象与原始对象具有相同的属性和值,并且它们不共享同一个内存地址。在 JavaScript 中,对象深拷贝可以使用遍历对象的方法来实现,具体步骤如下:
1. 创建一个新的空对象,用于存储深拷贝后的对象。
2. 遍历原始对象的属性,判断属性的类型,如果是基本数据类型(如字符串、数字等),直接复制到新对象中;如果是引用类型(如对象、数组等),则递归调用深拷贝函数进行复制,并将复制后的对象赋值给新对象的该属性。
3. 返回新对象。
实现代码如下:
```
function deepClone(obj) {
if (typeof obj !== "object" || obj === null) {
return obj;
}
let newObj = Array.isArray(obj) ? [] : {};
for (let key in obj) {
if (obj.hasOwnProperty(key)) {
newObj[key] = typeof obj[key] === "object" ? deepClone(obj[key]) : obj[key];
}
}
return newObj;
}
```
其中,`typeof obj !== "object" || obj === null` 用于判断当前属性是否为基本数据类型;`Array.isArray(obj) ? [] : {}` 判断当前属性是否为数组类型,如果是,则创建一个新的空数组;否则,创建一个新的空对象。在遍历属性时,`obj.hasOwnProperty(key)` 用于判断是否为自身属性,避免复制原型链上的属性。
阅读全文