JavaScript 中的浅复制与深复制
概述
在 JavaScript 中,复制对象或数组可以分为浅复制和深复制。在处理复杂的数据结构时,尤其是那些包含嵌套对象或数组的数据结构,理解其中的差异至关重要。
本指南解释了这些概念、它们的特征、实现它们的方法以及何时使用它们。
1. 浅拷贝
定义
浅拷贝创建对象或数组的顶级属性的副本。但是,对于嵌套对象或数组,仅复制引用,而不复制实际数据。
特点
- 仅复制第一级属性或元素。
- 嵌套对象或数组与原始对象/数组共享引用。
- 轻量级且高效,适用于简单结构,但不适合嵌套数据的独立复制。
1.1 使用 Object.assign()
const original = { a: 1, b: { c: 2 } }; const shallowCopy = Object.assign({}, original); shallowCopy.b.c = 42; console.log(original.b.c); // OUTPUT: 42 (The original object also affected due to shared reference)
1.2 使用扩展运算符 (...)
const original = { a: 1, b: { c: 2 } }; const shallowCopy = { ...original }; shallowCopy.b.c = 90; console.log(original.b.c); // OUTPUT: 90
1.3 让我们看一个数组方法浅复制的示例(切片、连接)
const original = [1, 2, [3, 4]]; const shallowCopy = original.slice(); shallowCopy[2][0] = 10; console.log(original[2][0]); // OUTPUT: 10
2. 深拷贝
定义
深层复制创建对象或数组的完全独立的副本。所有级别(包括嵌套结构)都会被递归复制。对复制结构的更改不会影响原始结构,反之亦然。
特点
- 递归复制结构的所有级别。
- 嵌套对象或数组独立于原始对象或数组。
- 计算量比浅拷贝重。
2.1 使用 JSON.stringify() 和 JSON.parse()
- 将对象转换为 JSON 字符串,然后再转换回新对象。
- 限制:不处理函数、日期、正则表达式或循环引用。
const original = { a: 1, b: { c: 2 } }; const deepCopy = JSON.parse(JSON.stringify(original)); deepCopy.b.c = 42; console.log(original.b.c); // OUTPUT: 2 (original remains unaffected)
2.2 使用 StructuredClone()
一种现代的深度复制方法,支持循环引用和日期等特殊对象。
const original = { a: 1, b: { c: 2 }, date: new Date() }; const deepCopy = structuredClone(original); deepCopy.b.c = 42; console.log(original.b.c); // OUTPUT: 2 console.log(original.date === deepCopy.date); // FALSE
2.3 使用自定义递归函数
手动处理复杂案例的灵活解决方案。
function deepCopy(obj) { if (obj === null || typeof obj !== "object") return obj; if (Array.isArray(obj)) return obj.map(deepCopy); const copy = {}; for (const key in obj) { if (obj.hasOwnProperty(key)) { copy[key] = deepCopy(obj[key]); } } return copy; } const original = { a: 1, b: { c: 2 } }; const deepCopyObj = deepCopy(original); deepCopyObj.b.c = 42; console.log(original.b.c); // OUTPUT: 2
3. 何时使用每一个?
浅复制
- 适用于没有嵌套结构的平面对象或数组。
- 当性能至关重要时,嵌套对象的共享引用是可以接受的。
深复制
- 对于复杂、深度嵌套的对象/数组。
- 当您需要副本和原件之间真正独立时。
4. 总结
浅复制
- 简单高效。
- 适合扁平结构或可接受共享引用的情况。
深复制
- 稳健并确保完全独立。
- 非常适合深层嵌套或复杂的结构。
这是对 JavaScript 中对象的浅拷贝和深拷贝的深入解释。根据您的用例和性能要求选择适当的方法。
以上是JavaScript 中的浅复制与深复制的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

Python和JavaScript开发者的薪资没有绝对的高低,具体取决于技能和行业需求。1.Python在数据科学和机器学习领域可能薪资更高。2.JavaScript在前端和全栈开发中需求大,薪资也可观。3.影响因素包括经验、地理位置、公司规模和特定技能。

实现视差滚动和元素动画效果的探讨本文将探讨如何实现类似资生堂官网(https://www.shiseido.co.jp/sb/wonderland/)中�...

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

如何在JavaScript中将具有相同ID的数组元素合并到一个对象中?在处理数据时,我们常常会遇到需要将具有相同ID�...

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

探索前端中类似VSCode的面板拖拽调整功能的实现在前端开发中,如何实现类似于VSCode...
