手写JS深拷贝-考虑各种数据类型和循环引用

本文探讨如何在JavaScript中实现深拷贝,包括使用`JSON.stringify`和`JSON.parse`的方法及其限制(如无法处理函数、Map、Set及循环引用),以及`Object.assign`的浅拷贝问题。并提出解决方案,强调要覆盖Object、Array、Map、Set以及解决循环引用的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用 `JSON.stringify` 和 `JSON.parse`

- 无法转换函数

- 无法转换 `Map` `Set`

- 无法转换循环引用

PS:其实普通对象使用 JSON API 的运算速度很快,但功能不全

使用 `Object.assign`

这根本就不是深拷贝,是浅拷贝

只考虑了简单的数组、对象

/**
 * 深拷贝 - 只考虑了简单的数组、对象
 * @param obj obj
 */
function cloneDeep(obj: any) {
    if (typeof obj !== 'object' || obj == null ) return obj

    let result: any
    if (obj instanceof Array) {
        result = []
    } else {
        result = {}
    }

    for (let key in obj) {
        if (obj.hasOwnProperty(key)) {            
            result[key] = cloneDeep(obj[key]) // 递归调用
        }
    }

    return result
}

思路

考虑 Object、Array、Map、Set

考虑循环引用

/**
 * @description 深拷贝
 */

/**
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值