浅拷贝只复制对象第一层属性,深层仍共享引用;深拷贝递归复制所有层级,完全断开引用。常用浅拷贝方法有Object.assign()、扩展运算符、slice()/concat();深拷贝可使用JSON.parse(JSON.stringify())(有限制)、递归实现、structuredClone()或Lodash的cloneDeep()。示例表明浅拷贝修改嵌套属性会影响原对象,而深拷贝不会。手动实现深拷贝需处理对象、数组、基本类型及特殊类型,但简单递归未解决循环引用,生产环境推荐成熟库。选择方式应根据数据类型、性能需求和兼容性综合考虑。

JavaScript中的深拷贝和浅拷贝主要针对引用类型(如对象、数组)在赋值时的行为差异。浅拷贝只复制对象的第一层属性,深层嵌套仍共享同一引用;而深拷贝会递归复制所有层级,完全断开引用关系。下面介绍几种常见的实现方式。
浅拷贝适用于只需复制第一层属性的场景,修改嵌套属性时仍会影响原对象。
示例:
// 对象浅拷贝深拷贝能彻底隔离新旧对象,适合复杂嵌套结构。
立即学习“Java免费学习笔记(深入)”;
示例:JSON方式
const obj1 = { a: 1, b: { c: 2 } };通过类型判断和递归,可以处理大多数情况。
function deepClone(obj) {这个版本能处理对象、数组、基本类型和嵌套结构,但未解决循环引用问题。生产环境建议使用成熟库。
选择拷贝方式需结合实际需求。
基本上就这些,理解原理后可根据项目需求灵活选择。
以上就是JavaScript深拷贝与浅拷贝的几种方式_javascript技巧的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号