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()方法实现了深拷贝。通过比较原始数据和复制后的数据,我们可以看到浅拷贝和深拷贝之间的区别。在浅拷贝中,如果更改了复制后的数据中的嵌套对象或数组,原始数据也会受到影响;而在深拷贝中,更改复制后的数据中的嵌套对象或数组不会影响原始数据。

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

相关文章
|
27天前
|
JSON JavaScript 数据格式
深拷贝和浅拷贝(js的问题)
深拷贝和浅拷贝(js的问题)
12 0
|
12天前
|
JavaScript
js浅拷贝与深拷贝的区别?
js浅拷贝与深拷贝的区别?
|
19天前
|
JavaScript 前端开发
js中浅拷贝和深拷贝的区别
js中浅拷贝和深拷贝的区别
23 1
|
4月前
|
JavaScript 前端开发
Js中浅拷贝和深拷贝有什么区别,如何实现?
在 JavaScript 中,浅拷贝(Shallow Copy)和深拷贝(Deep Copy)是两种常见的数据拷贝方式,它们的区别在于拷贝的程度
22 0
|
4月前
|
JSON JavaScript 数据格式
JS 浅拷贝深拷贝
JS 浅拷贝深拷贝
|
6月前
|
存储 JavaScript
js浅拷贝和深拷贝有啥区别?
js浅拷贝和深拷贝有啥区别?
|
9月前
|
JavaScript
js中数组的深拷贝的方法
js中数组的深拷贝的方法
104 1
|
9月前
|
JavaScript 前端开发
js深浅贝和浅拷贝区别
js深浅贝和浅拷贝区别
|
存储 JSON JavaScript
都2022年了你不会还没搞懂JS赋值拷贝、浅拷贝、深拷贝吧
面试中能把JS赋值拷贝、浅拷贝、深拷贝问题说明白的寥寥无几。今天笔者再来温习一遍,希望能对你有所帮助
118 0
|
JavaScript 前端开发
JavaScript 深拷贝和浅拷贝的区别是什么
深拷贝和浅拷贝的区别是什么
60 0