js深浅拷贝


这个名词听起来可能比较高级,但是还是比较容易理解的。市面上有些博客写的不完成,只是实现了半层次的深拷贝,只能对第一层次实现深拷贝,再多的层次就不行了,类似数组的slice,concat

深浅拷贝,在表象上表现为,如果我们把A复制给B,这个时候我们修改A如果B也跟着变化了,这个就是浅拷贝,但是如果B没有变就是深拷贝。

深浅拷贝发生在js的引用类型中,而且我们一般是用在数组和对象中。

浅拷贝

const obj = {
    id: 1,
    name: 'zx',
    age: 18,
    class: {
        id: 1
    }
}
const obj2 = obj
obj.id = 55
console.log(obj2.id) // 55

这种直接赋值的方式就是浅拷贝,只把指针地址复制了过来,还是共用的一块内存,所以修改一处的值都会改变。

深拷贝

function deepCopy(objParam) {
    let obj = Array.isArray(objParam) ? [] : {};
    for (const key in objParam) {
        if (objParam.hasOwnProperty(key)) {
            if (objParam[key] && typeof objParam[key] === "object") {
                obj[key] = deepCopy(objParam[key])
            }
            else {
                obj[key] = objParam[key]
            }
        }
    }
    return obj
}
const obj4 = deepCopy(obj)
obj4.class.id = 66

console.log(obj.class.id,obj4.class.id) // 1, 66

在这里还有一个邪术可以快速的深拷贝,但是听说这种方法不太好,通过JSON.stringify()和JSON.pasrse()这种方式原理也很简单,先把这个元素转化为一个字符串(值类型),然后再使用parse转化为引用类型。

扩充 hasOwnProperty和instanceof

在这里扩充两个知识点,hasOwnProperty和instanceof

instanceof 运算符用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。

例如:

const arr = [1, 2]
const obj = { id: 1 }
console.log(arr instanceof Array) // true
console.log(obj instanceof Array) // false

hasOwnProperty 判断一个对象上是否含有某个属性,返回布尔值。

例如:

const obj = {
    id: 1,
    name: 'zs',
    age: 18
}
console.log(obj.hasOwnProperty('name'))  // true
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值