手写 JS深拷贝
创始人
2024-03-31 04:34:29
0

一、为什么需要深拷贝?

深拷贝也是拷贝的一种。

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

值类型

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  =102console.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 resultif(obj instanceof Array) {result = []} else {result = {}}for (let key in obj) {// 保证key 不是原型的属性if (obj.hasOwnProperty(key)) {// 递归调用(重点)result[key] = deepClone(obj[key])}}return result}

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...
有效的括号 一、题目 给定一个只包括 '(',')','{','}'...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...