当前位置: 首页 > article >正文

如何在JS里进行深拷贝

什么是深拷贝?

深拷贝是指创建新对象的时候,对象拥有原始对象的所有属性的副本。

浅拷贝是指创建的新对象包含有原始对象的引用。也就是说浅拷贝仅复制对象的第一层结构,而不会递归地复制嵌套的对象数据。

如果仅使用浅拷贝创建对象的话,对新对象的更改,如果更改的是引用数据类型的属性时候,会改动原始对象。在实际应用中,我们期望对对象所做的修改不会影响到原对象,因此就需要使用深拷贝来复制对象。

深拷贝的方法

1. 使用 JSON.parse() 与 JSON.stringify()

这是一种简单的实现方式,先把对象使用stringify序列化,然后再用 parse 把它重新解析为对象,从而得到一个全新的对象。

const original = { a: 1, b: 2, c: { d: 3 } };
const copied = JSON.parse(JSON.stringify(original));

一般不推荐使用这种方式进行深拷贝,原因有:

  • 无法复制函数,undefined,Symbol等
  • 性能比较低

2. 使用结构化克隆 structuredClone()

这是一个javascript原生支持的深拷贝方法,可以很方便地进行深拷贝。

看看它在各个浏览器以及node的支持情况:

const original = { a: 1, b: 2, c: { d: 3 }};
const copied = structuredClone(original);
 

如果浏览器或者node环境支持这个方法的话,推荐使用结构化克隆方案。

3. 使用递归

通过递归遍历对象各个属性进行拷贝。

function deepClone(obj) {
    if (obj === null) return null;
    if (obj instanceof Date) return new Date(obj);
    if (obj instanceof RegExp) return new RegExp(obj);
    if (typeof obj !== 'object') return obj;

    const cloneObj = new obj.constructor();

    for (let key in obj) {
        if (obj.hasOwnProperty(key)) {
            cloneObj[key] = deepClone(obj[key]);
        }
    }
    return cloneObj;
}

const original = { a: 1, b: 2, c: { d: 3, e: new Date() }, x: [1,2,3]};
const copied = deepClone(original);

4. 使用三方库 lodash.cloneDeep()

lodash 库提供了很多很有用的工具类,如果项目里面已经有使用lodash的话,直接使用它的深拷贝也是可以的。

如果单纯为了深拷贝而引入三方库的话,那就要斟酌斟酌了,毕竟引入一个三方库还是会导致安装包增大不少的。

// 需要引入 Lodash 库
const _ = require('lodash');
const original = { a: 1, b: { c: 2 } };
const copied = _.cloneDeep(original);

总结

尽量使用结构化克隆 structuredClone,避免使用JSON方式。


http://www.kler.cn/a/505862.html

相关文章:

  • 3.Qt Quick-QML地图引擎之v4.3版本(新增动态轨迹线/海图/天地图街道/天地图卫星)
  • APISQL在线一键安装教程
  • ecmascript:2.模版字符串
  • C++ 文字识别OCR
  • React 第三方状态管理库相关 -- Redux MobX 篇
  • [AI部署-tensorRT] customlayer定义添加过程解析
  • K8S 节点选择器
  • Luggage Lock( The 2021 ICPC Asia Shenyang Regional Contest )
  • 《鸿蒙Next微内核:解锁人工智能决策树并行计算的加速密码》
  • (蓝桥杯)使用差分数组和前缀和解决区间更新问题——倒水
  • 9.7 visual studio 搭建yolov10的onnx的预测(c++)
  • 解锁企业数字化转型新力量:OpenCoze(开源扣子)
  • 备战蓝桥杯 队列和queue详解
  • git操作(bitbucket仓库)
  • 数据库(MySQL)练习
  • Android Room 持久化库的介绍及使用方法
  • 力扣经典题目之120.三角形最小路径和
  • PHP智慧小区物业管理小程序
  • MSSQL(Microsoft SQL Server)和 SQL(Structured Query Language)之间的区别
  • 计算机视觉与深度学习:使用深度学习训练基于视觉的车辆检测器(MATLAB源码-Faster R-CNN)
  • 202309 青少年软件编程等级考试C/C++ 二级真题答案及解析(电子学会)
  • qt QPainter setViewport setWindow viewport window
  • LLM实现视频切片合成 前沿知识调研
  • python如何随机生成数组
  • MyBatis-增删改查操作一些细节
  • Spark RPC 学习总结