深拷贝与浅拷贝


前言

今天无意看到一位同学说:concat返回一个新数组,可以实现数组的深拷贝,就亲自试了试!!!


简单的测试代码

	// 数组arr1中第一个元素为引用类型
    const arr1 = [{hobby:"看美女"}]
    const arr2 = [1,2]
    const newArr = arr1.concat(arr2)
    // newArr 此时为 [{hobby:"看美女"},1,2]
    newArr[0].name = '看动漫'
    console.log(newArr)
    console.log(arr1)

请添加图片描述
结果很显然,如果源数组中的元素为引用类型的话,新数组中的此元素和源数组中的此元素指向同一个内存地址,一变都变。如果源数组中都是基本数据类型的话,才可以说concat可以实现数组的"深拷贝"吧

一、简单理解一下浅拷贝和深拷贝?

浅拷贝:创建了一个新对象,这个对象中有着和原始对象属性值的相同的一份数据。
**** 如果属性值是基本类型,拷贝的就是基本属性的值
**** 如果属性值是引用类型,拷贝的就是属性的内存地址,如果其中一个对象改变了,就会影响到另一个对象

深拷贝:将一个对象从内存中完整的拷贝一份出来,从堆中开辟一块新的地址存放新对象,修改新对象不会影响源对象

二、深浅拷贝的实现方式

1.浅拷贝的常用实现方式

1、Object.assign(目标对象,源对象)
2、…扩展运算符
3、还可以写个浅拷贝函数实现:如下

function shallowClone(obj){
    if(obj === 'null' || typeof obj !== 'object') return
    let newObj = {}
    for (let key in obj) {
        if (obj.hasOwnProperty(key)) {
            newObj[key] = obj[key];
        }
    }
    return newObj;
}

2.深拷贝的常用实现方式

1、JSON.stringify(JSON.parse(obj))
2、通过JQuery的方法 $.extend(true,target,object1,…objectN) // 第一个参数必须是true,将后面全部对象深度拷贝到target身上
3、递归函数:如下

function deepClone(obj,newObj){
    for (let key in obj) {
        if (obj.hasOwnProperty(key)) {
            if(obj[key] instanceof Array){
                newObj[key] = []
                deepClone(obj[key],newObj[key])
            }else if(obj[key] instanceof Object){
                newObj[key] = {}
                deepClone(obj[key],newObj[key])
            }else {
                newObj[key] = obj[key];
            }
        }
    }
    return newObj;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值