JavaScript实现对象或者数组的深拷贝(深复制或者深克隆)

//深克隆
function deepClone(obj){
    var cloneObj
    //当obj是一个简单值时
    if(obj && typeof obj!=='object'){
        cloneObj=obj
        console.log("plain value")
    }
    //当obj是对象或者数组的时候
    else if(obj && typeof obj==='object'){
        console.log("object value")
        cloneObj=Array.isArray(obj) ? [] : {}

        //数组的元素或者对象的key
        for(var key in obj){
            if(obj.hasOwnProperty(key)){
                //如果是对象或者数组
                if(obj[key] && typeof obj[key]=== "object"){
                    cloneObj[key]=deepClone(obj[key])
                }else{
                    cloneObj[key]=obj[key]
                }
            }
        }
    }
    return cloneObj
}
var testObj={x:0,y:1,z:{a:3,b:4}}
var result=deepClone(testObj)
result.z.a=888
console.log(result)
console.log(testObj)

var testArray=[9,10,[2,4]]
var resultArray=deepClone(testArray)
resultArray[2][1]='aaa'
console.log(testArray)
console.log(resultArray)
在编程中,对象数组深拷贝涉及到数据结构的副本创建,确保新创建的对象与原对象独立,即使原对象发生改变也不会影响副本。这里有几种常见的深拷贝方式: 1. **浅拷贝(Shallow Copy)**: 对于简单类型(如基本数据类型)或值类型,拷贝的是它们的值。对于复杂类型如数组对象,浅拷贝实际上是创建了一个引用,两个变量指向的是同一个内存地址。这意味着对其中一个的修改会影响到另一个。 2. **深拷贝(Deep Copy)**: - **复制数组**:对于数组,可以逐个元素地进行深拷贝,创建一个新的数组并填充每个元素的深拷贝。例如,在JavaScript中可以使用`JSON.parse(JSON.stringify(array))`来实现。 - **复制对象**: a. 使用构造函数:创建新对象,然后递归遍历原对象,为每个属性创建新的值,而不是引用。例如在JavaScript中,`function deepCopy(obj) { return new obj.constructor(obj); }`。 b. 使用`Object.assign()`和扩展运算符...:结合使用,创建一个新的对象,并将所有属性从源对象复制过来,但不会创建循环引用。但是这种方法不适用于原型链中的对象。 c. 库方法:有些编程语言有现成的库函数或模块可以直接完成深拷贝操作,比如Python的`copy.deepcopy()`。 3. **克隆(Deep Cloning)**: 术语"克隆"通常用于描述复制的过程,特别是在讨论复杂的数据结构,如树、图或对象树时。 **相关问题**: 1. 浅拷贝和深拷贝的主要区别是什么? 2. 如何在JavaScript中避免对象属性的引用冲突进行深拷贝? 3. 如果数组中的元素是对象,应该如何正确地进行深拷贝
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

胡萝卜大王驾到通通闪开

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值