手写 JS深拷贝

一、为什么需要深拷贝?

深拷贝也是拷贝的一种。

拷贝无非就是值类型或引用类型的复制。

值类型

let a = 100;
let b = a;

a = 200;

console.log(b) // b = ?

b = ? ,毋庸置疑 b = 100

再来看看引用类型

const obj1 = {
    x: 100,
    y: 200
}
const obj2 = obj1
obj2.x  =102

console.log(obj1) // obj1 = ?

答案是 obj2 = { x: 102, y: 200 }

值类型和引用类型分配的地址不一样,如下图:

在这里插入图片描述
在这里插入图片描述
引用类型他们的指向地址一致,所以修改其中一个,指向该地址的变量会随着变化。

二、深拷贝

深拷贝就是拷贝引用类型,让他们不会互相影响。

方式一:(推荐)

使用 JSON 提供的parse 和 stringify 函数来进行深拷贝

JSON.parse(JSON.stringify(obj1))

方式二:

这个方法的核心就是使用递归将变量都变成值类型返回。

/**
 * 深拷贝
 * @param {Object} obj 要拷贝的对象
 */
function deepClone(obj = {}) {
    // obj 是 null 或者不是对象和数组,直接返回
    if(typeof obj !== 'object' || obj === null) {
        return obj
    }
    // 初始化返回结果
    let result
    if(obj instanceof Array) {
        result = []
    } else {
        result = {}
    }
    for (let key in obj) {
        // 保证key 不是原型的属性
        if (obj.hasOwnProperty(key)) {
            // 递归调用(重点)
            result[key] = deepClone(obj[key])
        }
    }
    return result
 }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值