首页 > web前端 > js教程 > 正文

在JavaScript中实现深拷贝有哪些高效且安全的方法?

夜晨
发布: 2025-10-04 23:31:02
原创
155人浏览过
structuredClone是现代浏览器推荐的深拷贝方法,支持多数数据类型并自动处理循环引用,但不支持函数、undefined等,需注意兼容性;2. 自定义递归函数通过WeakMap避免无限递归,兼容性好且可扩展,适合复杂场景;3. JSON序列化方法简洁但限制多,仅适用于纯数据对象;4. 第三方库如Lodash的cloneDeep功能全面且稳定,适合高要求场景但需引入依赖。选择应基于环境与需求。

在javascript中实现深拷贝有哪些高效且安全的方法?

在JavaScript中实现深拷贝,既要考虑性能,又要处理各种复杂数据类型。以下是几种高效且安全的方法,适用于不同场景。

1. 使用 structuredClone(现代浏览器推荐)

这是目前最安全、最简单的原生深拷贝方法,支持大多数常见数据类型,如对象、数组、Date、RegExp、Map、Set、ArrayBuffer等。

它自动处理循环引用,无需额外代码,性能良好。

示例:

阿贝智能
阿贝智能

阿贝智能是基于AI技术辅助创作儿童绘本、睡前故事和有声书的平台,助你创意实现、梦想成真。

阿贝智能 17
查看详情 阿贝智能
<pre class="brush:php;toolbar:false;">const original = { name: 'Alice', info: { age: 25 } };
const cloned = structuredClone(original);
cloned.info.age = 30;
console.log(original.info.age); // 25,未受影响
登录后复制
注意:不支持函数、undefined、Symbol 和 WeakMap/WeakSet。仅在现代浏览器和 Node.js(v17+)中可用。

2. 自定义递归深拷贝函数(兼容性好)

当需要兼容旧环境或控制拷贝行为时,可手动实现深拷贝函数,处理循环引用和特殊类型。

关键点是使用 WeakMap 记录已访问对象,避免无限递归。

立即学习Java免费学习笔记(深入)”;

示例:

<pre class="brush:php;toolbar:false;">function deepClone(obj, seen = new WeakMap()) {
  if (obj === null || typeof obj !== 'object') return obj;
  if (obj instanceof Date) return new Date(obj);
  if (obj instanceof RegExp) return new RegExp(obj);
  if (seen.has(obj)) return seen.get(obj);

  const clone = Array.isArray(obj) ? [] : {};
  seen.set(obj, clone);

  for (let key in obj) {
    if (Object.hasOwn(obj, key)) {
      clone[key] = deepClone(obj[key], seen);
    }
  }
  return clone;
}
登录后复制
此方法兼容性高,可扩展支持 Map、Set 等类型,适合需要精细控制的场景。

3. 利用 JSON 序列化(简单但有限制)

通过 JSON.parse(JSON.stringify()) 实现深拷贝,写法简洁,性能尚可。

但存在明显限制:

  • 忽略 undefined、函数、Symbol
  • 无法处理循环引用(会报错)
  • Date 对象会被转为字符串
  • Map、Set、RegExp 等类型无法正确复制

仅建议用于纯数据对象(POJO),如配置项、API 响应数据等简单结构。

4. 第三方库(功能全面)

如 Lodash 的 _.cloneDeep(),经过充分测试,支持几乎所有类型,包括函数和循环引用。

优点是稳定可靠,缺点是引入额外依赖。

示例:

<pre class="brush:php;toolbar:false;">const _ = require('lodash');
const cloned = _.cloneDeep(original);
登录后复制
适合项目已使用 Lodash 或对深拷贝要求极高的场景。

基本上就这些。选择哪种方法取决于你的运行环境和数据复杂度。structuredClone 是未来趋势,自定义实现更灵活,JSON 方法仅限简单场景,第三方库则提供开箱即用的稳定性。

以上就是在JavaScript中实现深拷贝有哪些高效且安全的方法?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号