JavaScript深拷贝方法structuredClone如何使用(javascript,开发技术)

时间:2024-05-03 08:32:28 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    JavaScript%E6%B7%B1%E6%8B%B7%E8%B4%9D%E6%96%B9%E6%B3%95structuredClone%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8

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

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

浅拷贝:就是只拷贝对象的第一层。引用了更深层次的内容。可以使用扩展运算符 ... 或使用 Object.assign() 在 JavaScript 中实现浅拷贝。

深拷贝:是指对象的所有层次都被复制。这是对象的真实副本。可以使用 JSON.parse() + JSON.stringify() 执行此操作,现在,还可以使用原生方法 structuredClone() 执行此操作。

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

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

语法如下:

value:被克隆的对象。可以是任何结构化克隆支持的类型。

transfer:为可选参数,是一个可转移对象的数组,里面的 并没有被克隆,而是被转移到被拷贝对象上。

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

下面是示例代码:

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

更新第一层克隆对象的属性后,原始属性不会更新。

在更深层次更新属性后,原始属性既不更新。发生这种情况是因为在这种情况下,还复制了更深层次。

而对于浅拷贝对象 shallowCopy 来说,其值会随着对象 deepCopy 的变化而变化,在项目开发中很容易带来BUG

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

本文:JavaScript深拷贝方法structuredClone如何使用的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:Spring AOP的概念与实现过程是什么下一篇:

5 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18