let arr = [1,2,3,4];
function deepClone(obj) {
//定义对象来判断当前的参数是数组还是对象
let objClone = Array.isArray(obj) ? [] : {};
//如果obj存在并且为对象
if(obj && typeof obj == "object") {
for(let key in obj) {
if(obj.hasOwnProperty(key)) {
//如果obj的子元素为对象,那么递归(层级遍历)
if(obj[key] && typeof obj[key] == "object") {
objClone[key] = deepClone(obj[key]);
} else {
//如果不是,直接赋值
objClone[key] = obj[key];
}
}
}
}
return objClone;
}
let arr1 = deepClone(arr);
console.log(arr1);//[ [1, 2, 3, 4]]
arr1[2] = 5;
console.log(arr1);//[1, 2, 5, 4]
console.log(arr);//[1, 2, 3, 4]
深拷贝
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 对象的深拷贝实现原理: 定义一个新的对象,遍历源对象的属性 并 赋给新对象的属性 闭包:子函数能被外部调用到,则该...
- 在说深拷贝与浅拷贝前,我们先看两个简单的案例: //案例1var num1 = 1, num2 = num1;co...