js中浅拷贝和深拷贝的区别

简介: js中浅拷贝和深拷贝的区别

在JavaScript中,浅拷贝(Shallow Copy)和深拷贝(Deep Copy)是两种不同的复制对象的方法,它们之间存在一些重要的区别。

  1. 浅拷贝(Shallow Copy):
    浅拷贝只复制对象的顶层属性,如果属性是对象或数组,则复制的是引用,而不是实际的对象。这意味着,如果更改了复制后的对象中的嵌套对象或数组,原始对象的相应属性也会被更改。这是因为浅拷贝只是简单地复制了外层的引用,而没有复制内部的对象或数组。
  2. 深拷贝(Deep Copy):
    深拷贝则完全不同,它会递归地复制对象的所有层级属性,包括对象和数组。这意味着,如果复制后的对象中的嵌套对象或数组被更改,原始对象的相应属性不会受到影响。深拷贝创建了一个全新的、独立的副本,包括内部的对象和数组。

以下是一个使用JavaScript实现浅拷贝和深拷贝的示例代码:

javascript// 定义一个复杂的数据结构
let data = {
name: 'John',
age: 25,
address: {
street: '123 Main St',
city: 'Anytown',
state: 'CA',
zip: '12345'
},
phoneNumbers: ['123-456-7890', '987-654-3210']
};
// 浅拷贝示例
let shallowCopy = Object.assign({}, data);
console.log('浅拷贝结果:', shallowCopy);
// 修改原始数据中的嵌套对象或数组
data.address.city = 'New York';
data.phoneNumbers[1] = '555-123-4567';
console.log('原始数据:', data);
console.log('浅拷贝后的数据:', shallowCopy); // 浅拷贝后的数据会受到原始数据的影响
// 深拷贝示例(使用JSON.stringify和JSON.parse方法)
let deepCopy = JSON.parse(JSON.stringify(data));
console.log('深拷贝结果:', deepCopy);
// 修改复制后的数据中的嵌套对象或数组
deepCopy.address.city = 'London';
deepCopy.phoneNumbers[1] = '098-765-4321';
console.log('深拷贝后的数据:', deepCopy); // 深拷贝后的数据不会影响原始数据

在这个示例中,我们首先定义了一个复杂的数据结构data,它包含了一个对象、一个数组以及一个嵌套的对象和数组。然后,我们使用Object.assign()方法实现了浅拷贝,并使用JSON.stringify()JSON.parse()方法实现了深拷贝。通过比较原始数据和复制后的数据,我们可以看到浅拷贝和深拷贝之间的区别。在浅拷贝中,如果更改了复制后的数据中的嵌套对象或数组,原始数据也会受到影响;而在深拷贝中,更改复制后的数据中的嵌套对象或数组不会影响原始数据。

总结来说,浅拷贝只复制对象的顶层属性,复制的是引用而非实际的对象;而深拷贝会递归地复制对象的所有层级属性,创建一个全新的、独立的副本。在处理复杂的数据结构时,深拷贝更为安全和可靠。

相关文章
|
28天前
|
JavaScript 前端开发
js中的bind,call,apply方法的区别以及用法
JavaScript中,`bind`、`call`和`apply`均可改变函数的`this`指向并传递参数。其中,`bind`返回一个新函数,不立即执行;`call`和`apply`则立即执行,且`apply`的参数以数组形式传递。三者在改变`this`指向及传参上功能相似,但在执行时机和参数传递方式上有所区别。
26 1
|
1月前
|
设计模式 JavaScript 前端开发
js中new和object.creat区别
【10月更文挑战第29天】`new` 关键字和 `Object.create()` 方法在创建对象的方式、原型链继承、属性初始化以及适用场景等方面都存在差异。在实际开发中,需要根据具体的需求和设计模式来选择合适的方法来创建对象。
|
2月前
|
存储 JavaScript 前端开发
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
JavaScript 数据类型分为基本数据类型和引用数据类型。基本数据类型(如 string、number 等)具有不可变性,按值访问,存储在栈内存中。引用数据类型(如 Object、Array 等)存储在堆内存中,按引用访问,值是可变的。本文深入探讨了这两种数据类型的特性、存储方式、以及检测数据类型的两种常用方法——typeof 和 instanceof,帮助开发者更好地理解 JavaScript 内存模型和类型检测机制。
108 0
JavaScript 数据类型详解:基本类型与引用类型的区别及其检测方法
|
2月前
|
JavaScript 前端开发
JavaScript中的深拷贝与浅拷贝
JavaScript中的深拷贝与浅拷贝
51 4
|
2月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
21 2
|
2月前
|
JavaScript 前端开发
【JavaScript】let,const和var的区别
总的来说,随着ECMAScript 6(ES6)及后续版本的推广,`let`和 `const`因其增强的块级作用域和对变量行为的更严格控制,逐渐成为现代JavaScript编码实践中推荐使用的变量声明方式。而 `var`由于其历史遗留的局限性,正逐渐被边缘化,但在维护老代码或处理特定兼容性需求时仍需了解。
42 3
|
3月前
|
JavaScript 前端开发
JavaScript中单引号和双引号的效果的一点区别
JavaScript中单引号和双引号的效果的一点区别
|
7月前
|
JSON 前端开发 JavaScript
【面试题】JavaScript 深拷贝和浅拷贝 高级
【面试题】JavaScript 深拷贝和浅拷贝 高级
|
4月前
|
JavaScript 前端开发
JavaScript中的深拷贝与浅拷贝
JavaScript中的深拷贝与浅拷贝
43 2
|
4月前
|
JavaScript 前端开发
JavaScript中的深拷贝和浅拷贝的实现讲解
在JavaScript中,浅拷贝与深拷贝用于复制对象。浅拷贝仅复制基本类型属性,对于引用类型仅复制引用,导致双方共享同一数据,一方修改会影响另一方。深拷贝则完全复制所有层级的数据,包括引用类型,确保双方独立。浅拷贝可通过简单属性赋值实现,而深拷贝需递归复制各层属性以避免共享数据。
75 1