美文网首页
TypeScript 中的深拷贝和浅拷贝

TypeScript 中的深拷贝和浅拷贝

作者: 华山令狐冲 | 来源:发表于2023-05-18 11:59 被阅读0次

什么是深拷贝

在JavaScript/TypeScript中,深拷贝是指创建一个对象的副本,而不仅仅是创建对原始对象的引用。对复制的对象进行的任何更改都不会影响原始对象,反之亦然。

这个副本将完全复制基础对象,包括每个嵌套级别的所有属性和字段,生成新的引用。

为什么需要深拷贝

在Angular中,深拷贝的目的是创建一个与原始对象完全独立的新对象实例。这在您想要更改对象而不影响原始对象时非常有用,例如在处理不应该被修改的数据时。

例如,在Angular中创建一个新组件时,您可能希望将数据传递给该组件,而不修改原始数据。使用深拷贝可以确保在组件内部对数据所做的任何更改都不会影响原始数据。

此外,当您拥有一个庞大而复杂的数据结构时,使用深拷贝可以有助于创建数据的新副本并保持原始数据的完整性。

总的来说,使用深拷贝在Angular中处理数据是一种良好的实践,可以避免由于修改原始数据而导致的意外副作用。

深拷贝 vs 浅拷贝

另一方面,浅拷贝创建了对象的新实例,但只复制嵌套对象的引用,而不是嵌套对象本身。这意味着在复制的对象中对嵌套对象进行的任何更改也会影响原始对象,反之亦然。

当我们谈论Angular深拷贝时,浅拷贝也是不能被忽视的。我将在未来的一篇博客文章中讨论浅拷贝。

深拷贝的一些实现方式

JSON.parse

此方法使用内置的 JSON 对象将对象转换为 JSON 字符串,然后将其解析回对象。 这种方法很简单,适用于大多数基本对象。

let obj2 = JSON.parse(JSON.stringify(obj));

这不适用于具有方法或循环引用的对象。如果您的对象包含:日期、函数、未定义、Infinity、RegExp、Maps、Sets、Blob、FileLists、ImageDatas、稀疏数组、类型化数组或其他复杂类型,也不适合采用这种方法。

lodash.cloneDeep

下面这种方法使用 lodash 库创建对象的深拷贝。

您需要先通过运行 npm install lodash 来安装 lodash 库,然后将其导入到您要使用它的组件或服务中:

import * as _ from 'lodash';
let obj2 = _.cloneDeep(obj);

Object.assign

此方法使用内置的 Object.assign 方法创建具有原始对象属性的新对象。 这种方法也很简单,适用于大多数基本对象,但它只创建一个浅拷贝。

let obj2 = Object.assign({}, obj);

这是嵌套对象的浅拷贝。 所以不要用于大型 JavaScript 对象。
它创建对象的浅表副本,原始对象中的嵌套对象仍然是对原始对象的引用。

几种方法的性能比较

相关文章

  • Objective-C中的浅拷贝和深拷贝

    Objective-C中的浅拷贝和深拷贝 Objective-C中的浅拷贝和深拷贝

  • JS中的深拷贝与浅拷贝

    知乎:js中的深拷贝和浅拷贝? 掘金: js 深拷贝 vs 浅拷贝 前言 首先深拷贝与浅拷贝只针对 Object,...

  • iOS深拷贝(MutableCopy)与浅拷贝(Copy)的区别

    深拷贝和浅拷贝的概念 iOS中有深拷贝和浅拷贝的概念,那么何为深拷贝何为浅拷贝呢?浅拷贝:浅拷贝并不拷贝对象本身,...

  • copy和mutableCopy的区别

    copy和mutableCopy的区别 深拷贝和浅拷贝的区别 在OC中对象的拷贝方式有两种:深拷贝和浅拷贝.浅拷贝...

  • java中的深拷贝和浅拷贝

    简单记录一下java中的深拷贝和浅拷贝,深拷贝和浅拷贝只是针对对象而言的. 1 深拷贝代码 2 浅拷贝代码 3 测...

  • 浅拷贝和深拷贝

    本文参考:JavaScript中的浅拷贝和深拷贝js 深拷贝 vs 浅拷贝深入剖析 JavaScript 的深复制...

  • JS中对象的复制

    JS中的对象复制分为两种情况:深拷贝和浅拷贝。深拷贝和浅拷贝的区别在于对数组和对象的拷贝,对它们拷贝时浅拷贝只是拷...

  • Java基础 - 深拷贝和浅拷贝

    Java 的深拷贝和浅拷贝 什么是深拷贝、浅拷贝 (深克隆、浅克隆)? 在 Java 中,数据类型分为 基本数据类...

  • iOS面试题-第二页

    11.深拷贝和浅拷贝的理解. 深拷贝;拷贝的内容. 浅拷贝:拷贝的指针. 深拷贝如: NSMutableDicti...

  • Objective-C中的浅拷贝和深拷贝

    Objective-C中的浅拷贝和深拷贝IOS开发之深拷贝与浅拷贝(mutableCopy与Copy)详解iOS ...

网友评论

      本文标题:TypeScript 中的深拷贝和浅拷贝

      本文链接:https://www.haomeiwen.com/subject/depmsdtx.html