js深拷贝和浅拷贝的区别

一:浅拷贝

let obj1 = {
    a: 1
}

let obj2 = obj1;

obj2.a = 2;

console.log("obj1", obj1);
console.log("obj2", obj2);

我们可以看到obj1和obj2的属性a的值都变为2了,改变obj2的值,源对象obj1的值也跟着变,像这种情况成为浅拷贝。

二:深拷贝

let obj1 = {
    a: 1
}

let obj2 = JSON.parse(JSON.stringify(obj1));

obj2.a = 2;

console.log("obj1", obj1);
console.log("obj2", obj2);

使用JSON.stringify和JSON.parse方法后,改变obj2的值,源对象obj1的值没有改变,这种称为深拷贝。

下面是实现深拷贝的方法,这些方法有使用区别

1:Object.assign()

2:JSON.stringify和JSON.parse

3:递归的方式实现对象的深拷贝

①Object.assign()

let obj1 = {
    CnName: "姓名1",
    childZi: {
        EnName: "name1"
    }
}

let obj2 = Object.assign({}, obj1);

obj2.CnName = "姓名2";
obj2.childZi.EnName = "name2";

console.log("obj1", obj1);
console.log("obj2", obj2);

我们可以看到改变拷贝对象obj2非嵌套的值,源对象obj1的值CnName不会跟着变;改变拷贝对象obj2内嵌套的对象值(obj2.childZi.EnName)后,原始对象嵌套的值也会跟着改变;Object.assign() 只能实现部分深拷贝。

②JSON.stringify和JSON.parse

let obj1 = {
    CnName: "姓名1",
    childZi: {
        EnName: "name1"
    },
    childFunc: function(){
        return this.CnName
    }
}

let obj2 = JSON.parse(JSON.stringify(obj1));

obj2.CnName = "姓名2";
obj2.childZi.EnName = "name2";

console.log("obj1", obj1);
console.log("obj2", obj2);

JSON.stringify和JSON.parse会丢失源对象里面的函数childFunc;优点是子对象也实现了深拷贝,childZi里面的EnName没有随着obj2而改变。

③递归的方式实现对象的深拷贝

function myDeepClone(obj){
    let clone;
    if(obj == null || typeof obj != 'object') return obj;
    clone = Object.assign({}, obj)
    Object.keys(clone).forEach(key => {
        clone[key] = typeof obj[key] === 'object'?myDeepClone(obj[key]):obj[key]
    })
    if(Array.isArray(obj)){
        clone.length = obj.length
        clone = Array.from(clone)
    }
    return clone
}

以上的自定义递归方法不够全面,但对于基本的对象( {} )和数组( [] )深拷贝还是够用的,要想实现复杂对象的深拷贝可以使用 lodash 的 cloneDeep 方法,这个方法实现深拷贝是比较完美的。

// 安装 lodash :npm i lodash
// main.js引入
import lodash from "lodash";
Vue.prototype.$cloneDeep = lodash.cloneDeep;

洽西游戏网

洽西游戏icon-default.png?t=N7T8http://www.qiaxi.cc

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
深拷贝浅拷贝JavaScript中常用的两种拷贝方式,它们的区别在于对于对象类型的处理方式不同。深拷贝会在内存中重新开辟一段新的存储空间,使得两个对象指向两个不同的堆内存数据,从而实现改变互不影响。而浅拷贝则只是拷贝了对象的引用,即地址拷贝,两个对象最终指向同一块内存空间。 具体来说,当使用浅拷贝时,对于基本类型的值,会进行值拷贝,即两个变量分别保存了相同的值。但对于对象类型,浅拷贝只会拷贝对象的地址,即两个变量最终指向同一个对象。因此,当修改其中一个变量的属性时,会影响到另一个变量。 而深拷贝则会复制整个对象的值,并为其分配新的内存空间,使得两个对象相互独立。这意味着,当修改其中一个变量的属性时,不会影响到另一个变量。深拷贝可以通过多种方式实现,例如递归复制对象的每一个属性,或者使用JSON.parse(JSON.stringify(obj))方法进行拷贝。 需要注意的是,在深拷贝中,当对象只有一级属性时,整个对象会被深拷贝。但当对象中有多级属性时,只有第一级属性会进行深拷贝,后续级别的属性会进行浅拷贝。此外,还可以使用slice()和concat()方法进行浅拷贝。 综上所述,深拷贝浅拷贝区别在于对象类型的处理方式不同。深拷贝会创建一个全新的对象并复制其值,使得两个对象互不影响;而浅拷贝只是复制对象的引用,使得两个对象最终指向同一个内存空间,修改其中一个对象会影响到另一个对象。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [深拷贝浅拷贝区别javascript篇)](https://blog.csdn.net/qq_48637854/article/details/124982976)[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_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [JavaScript浅拷贝深拷贝的概念及区别](https://blog.csdn.net/Yannick_H/article/details/125361201)[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_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值