JavaScript的深浅拷贝

简介: JavaScript的深浅拷贝

在JavaScript中,拷贝一个对象是一项非常常见的操作,常用的方法包括深拷贝和浅拷贝。但是,不同的拷贝方法会产生不同的效果和影响,因此深入了解和掌握深浅拷贝的概念和实现方法是非常重要的。

浅拷贝

首先我们来了解一下浅拷贝的概念。简单地说,浅拷贝就是只复制了对象的引用,而没有复制对象本身。也就是说,如果我们修改了浅拷贝后的对象,原对象也会跟着被修改。

那么如何实现浅拷贝呢?一种简单的方法是使用Object.assign()方法。例如,我们有一个原始对象originalObj:


const originalObj = {a: 1, b: {c: 2}};


我们可以使用Object.assign()方法将它进行浅拷贝:


const shallowCopyObj = Object.assign({}, originalObj);


此时,shallowCopyObj和originalObj的值相同。但是,如果我们修改shallowCopyObj中的某个属性值,那么originalObj也会被修改:


shallowCopyObj.b.c = 3;
console.log(originalObj.b.c); // 输出 3


这是因为浅拷贝只是复制了原对象的引用,而b属性引用的对象实际上是同一个。

深拷贝

相对于浅拷贝,深拷贝会复制整个对象,包括它的所有属性和嵌套对象。这种拷贝方式可以独立地修改新对象,不会对原对象产生任何影响。

实现深拷贝的方法有很多,但是需要注意的是,不同的实现方式对于不同的对象结构可能会有不同的性能和效果。一些常用的方法包括JSON.parse()和JSON.stringify()方法、递归方法等。

例如,我们有一个嵌套的对象originalObj:


const originalObj = {a: 1, b: {c: 2}};


我们可以使用递归方法实现深拷贝:


function deepClone(obj) {
  let result = Array.isArray(obj) ? [] : {};
  for (let key in obj) {
    if (obj.hasOwnProperty(key)) {
      if (typeof obj[key] === 'object' && obj[key] !== null) {
        result[key] = deepClone(obj[key]);
      } else {
        result[key] = obj[key];
      }
    }
  }
  return result;
}
const deepCopyObj = deepClone(originalObj);


此时,deepCopyObj和originalObj是两个独立的对象,修改其中一个不会影响另一个:


deepCopyObj.b.c = 3;
console.log(originalObj.b.c); // 输出


需要注意的是,递归方法虽然可以实现深拷贝,但是在处理特殊对象时可能会出现问题。例如,对于包含循环引用的对象,递归方法可能会导致死循环或栈溢出等问题。

在实现深拷贝时,可以考虑使用第三方库,例如Lodash、jQuery等,这些库已经对深拷贝进行了充分的测试和优化。


选择浅拷贝还是深拷贝?


选择浅拷贝还是深拷贝,取决于我们的实际需求和对对象引用关系的理解。

浅拷贝适用于对象结构较简单、属性值为基本类型或不需要修改原对象的情况,例如在实现Redux的reducer函数中使用浅拷贝可以保证不修改原始的state对象。

深拷贝适用于对象结构较复杂、包含嵌套对象或需要独立修改新对象的情况,例如在实现撤销重做功能时需要保存历史状态,此时使用深拷贝可以保证历史状态的独立性。

在实际开发中,我们需要根据具体情况灵活选择浅拷贝还是深拷贝,以保证代码的正确性和效率。同时,也需要注意拷贝对象的大小和复杂度,避免出现性能问题。

目录
相关文章
|
8月前
|
JSON JavaScript 前端开发
JavaScript 中更现代的深拷贝方法!
JavaScript 中更现代的深拷贝方法!
144 0
|
7月前
|
JSON JavaScript 前端开发
【JavaScript】JavaScript中的深拷贝与浅拷贝详解:基础概念与区别
JavaScript 中,理解数据拷贝的深浅至关重要。浅拷贝(如扩展运算符`...`、`Object.assign()`)仅复制对象第一层,共享内部引用,导致修改时产生意外联动。深拷贝(如自定义递归函数、`_.cloneDeep`或`JSON.parse(JSON.stringify())`)创建独立副本,确保数据隔离。选择哪种取决于性能、数据独立性和资源需求。深拷贝虽慢,但确保安全;浅拷贝快,但需小心引用共享。在面试中,理解这些概念及其应用场景是关键。
157 4
【JavaScript】JavaScript中的深拷贝与浅拷贝详解:基础概念与区别
|
7月前
|
JavaScript 前端开发 安全
深入探索JavaScript中的structuredClone:现代深拷贝的解密指南
深入探索JavaScript中的structuredClone:现代深拷贝的解密指南
59 0
|
JSON JavaScript 前端开发
超详细的JavaScript深拷贝实现
超详细的JavaScript深拷贝实现
264 0
超详细的JavaScript深拷贝实现
|
存储 JSON JavaScript
《现代Javascript高级教程》JavaScript深拷贝与浅拷贝
JavaScript深拷贝与浅拷贝 引言 在JavaScript中,对象的拷贝是一项常见的操作。浅拷贝和深拷贝是两种常用的拷贝方式。浅拷贝只复制对象的引用,而深拷贝创建了一个全新的对象,包含与原始对象相同的值和结构。深拷贝和浅拷贝各有适用的场景和注意事项。本文将详细介绍如何实现一个完整而优雅的深拷贝函数,处理循环引用和特殊类型,优化性能,并探讨深拷贝和浅拷贝的应用场景、注意事项和相关属性。
97 0
|
JavaScript 前端开发
|
JavaScript 前端开发 索引
《JavaScript高级程序设计》__ 基本引用类型(上)
前言 大家好,我是HoMeTown,web领域有一本神书大家应该都有看过,这本书我看过两遍,但是每次看都是粗粗的略过一些重要的知识点,甚至一些面试过程中的问题,在这本书里都能找到答案。
119 0
|
JavaScript 前端开发
《JavaScript高级程序设计》__ 基本引用类型(下)
前言 大家好,我是HoMeTown,web领域有一本神书大家应该都有看过,这本书我看过两遍,但是每次看都是粗粗的略过一些重要的知识点,甚至一些面试过程中的问题,在这本书里都能找到答案。
123 0
|
JavaScript 前端开发 索引
重学Javascript之引用类型
重学Javascript之引用类型
|
JSON JavaScript 前端开发
Javascript对象的深浅拷贝
Javascript对象的深浅拷贝
Javascript对象的深浅拷贝