使用递归函数来实现一个对象的深拷贝

47 阅读1分钟

function copy(obj) { let newObj = null; // 声明一个对象来存储拷贝之后的内容

// 判断数据类型是否是复杂的数据类型,如果是则调用自己,如果不是则直接赋值即可!
// 由于null不可以循环但是他的类型又是object,所以这个需要对null进行判断
if (typeof(obj) == 'object' && obj !== null){
    // 声明一个变量用以存储拷贝出来的值,根据参数的具体数据类型声明不同的类型来存储
    newObj = obj instanceof Array? [] : {};
    // 循环obj的每一项,如果里面还有复杂的数据类型的话,则直接利用递归函数再次调用。
    for(let i in obj){
        newObj[i] = copy(obj[i])
    }
} else {
    newObj = obj
}
return newObj; // 函数没有返回的值的话,则为undefined

} let obj = { // 原对象,包含字符串,对象,函数,数组等不同类型。 name: "test", main:{ a:1, b:2 }, fn:function(){

}, firends:[1,2,3,[44,55]];

}

let obj1 = copy(obj); obj1.name = '修改值'; obj1.main.a = 110; console.log(obj,obj1)