JavaScript
主页 > 网络编程 > JavaScript >

JavaScript深拷贝方法structuredClone使用介绍

2023-11-09 | 佚名 | 点击:

对于深拷贝,最容易也应该是常见的方法是使用 JSON.parse() + JSON.stringify() ,还有一个借助第三方脚本库 lodash ,其中方法 cloneDeep 可以实现深拷贝。现在可以使用原生的 structuredClone() 方法。

浅拷贝与深拷贝

首先,先来了解一下浅拷贝和深拷贝的区别:

使用 structuredClone 进行深拷贝

原生 structuredClone() 方法使用结构化克隆算法创建给定值的深层拷贝。

结构化克隆算法用于复制复杂 JavaScript 对象的算法。通过来自 Worker 的 postMessage() 或使用 IndexedDB 存储对象时在内部使用。它通过递归输入对象来构建克隆,同时保持先前访问过的引用的映射,以避免无限遍历循环。

语法如下:

1

2

structuredClone(value)

structuredClone(value, { transfer })

返回值:返回值是原始值的深拷贝。

下面是示例代码:

1

2

3

4

5

6

7

8

const objProfile = { name: "DevPoint", detail: { age: 30 } };

const deepCopy = structuredClone(objProfile);

const shallowCopy = { ...deepCopy };

console.log(shallowCopy); // {"name": "DevPoint", "detail": {  "age": 35 } }

deepCopy.name = "天行无忌";

deepCopy.detail.age = 35;

console.log(objProfile); // {"name": "DevPoint", "detail": {  "age": 30 } }

console.log(deepCopy); // {"name": "天行无忌", "detail": {  "age": 35 } }

正如在此代码片段中所见:

structuredClone() 现在可在所有主流浏览器和运行时(如 Node.js 或 Deno)的最新版本中使用。

原文链接:
相关文章
最新更新