Object转实体对象详解

一、小标题:从Object转对象

在JavaScript中,我们可以使用Object对象来表示一个无序的键/值对集合。因此,从Object转换为对象是相当容易的。

  // Object
  const obj = {
    name: 'John',
    age: 30
  };
  
  // Object转对象
  const newObj = { ...obj };

由于Object的键/值对是无序的,上述代码可以保证新对象的键/值对与原对象的键/值对是一致的。

二、小标题:从Object转实体

实体是指一个具体的事物,比如一个人、一件物品等。在JavaScript中,通常使用类(class)来定义实体。从Object转换为实体需要我们手动定义实体,并将Object的键/值对转换为实体的属性。

class Person {
  constructor(name, age) {
    this.name = name;
    this.age = age;
  }
}

// Object
const obj = {
  name: 'John',
  age: 30
};

// Object转实体
const person = new Person(obj.name, obj.age);

在上述代码中,我们手动定义了一个Person类,它有两个属性:name和age。然后我们根据Object的键/值对创建了一个新的Person实例。

三、小标题:从Object强转对象

强制类型转换是指将一个变量从一种类型转换为另一种类型。在JavaScript中,我们可以使用parseInt、parseFloat、toString等函数来进行强制类型转换。

从Object强转为对象需要我们使用JSON.stringify和JSON.parse函数。我们先使用JSON.stringify将Object转换为字符串,然后使用JSON.parse将字符串转换为对象。

// Object
const obj = {
  name: 'John',
  age: 30
};

// Object强转对象
const obj2 = JSON.parse(JSON.stringify(obj));

在上述代码中,我们将Object转换为字符串,然后又将字符串转换为对象。obj2与obj拥有相同的键/值对。

四、小标题:从Object强转实体

与从Object强转对象类似,我们也可以从Object强转实体。需要我们先将Object转换为字符串,然后再根据实体的属性手动创建一个新的实体。

class Person {
  constructor(name, age) {
    this.name = name;
    this.age = age;
  }
}

// Object
const obj = {
  name: 'John',
  age: 30
};

// Object强转实体
const str = JSON.stringify(obj);
const {name, age} = JSON.parse(str);
const person = new Person(name, age);

在上述代码中,我们先创建了一个Person类,然后将Object转换为字符串,并解析出新的键/值对。最后根据解析出的键/值对创建一个新的Person实例。

五、小标题:工具类

在实际开发过程中,我们可能会遇到需要从Object转换为实体的情况。为了方便地进行转换,我们可以编写一个工具类,将上述过程封装起来。

class Convert {
  static toObject(obj) {
    return { ...obj };
  }

  static toEntity(clazz, obj) {
    const keys = Object.keys(obj);
    const args = keys.map(key => obj[key]);

    return new clazz(...args);
  }

  static toObjectFromString(str) {
    return JSON.parse(str);
  }

  static toEntityFromString(clazz, str) {
    const obj = JSON.parse(str);
    const keys = Object.keys(obj);
    const args = keys.map(key => obj[key]);

    return new clazz(...args);
  }
}

// 使用示例
const obj = { name: 'John', age: 30 };
const person1 = Convert.toEntity(Person, obj);
const str = JSON.stringify(obj);
const person2 = Convert.toEntityFromString(Person, str);

在上述代码中,我们编写了一个Convert工具类,它有四个静态方法:toObject、toEntity、toObjectFromString和toEntityFromString。toObject方法直接返回一个Object,toEntity方法需要我们传入一个实体类和一个Object,并返回一个新的实体。toObjectFromString和toEntityFromString方法分别将字符串转换为Object和实体。

六、小标题:从Object对象转Map

Map是一种可迭代的数据结构,其中的键值对是按顺序排列的。在JavaScript中,我们可以使用Object.entries函数将Object对象转换为可迭代的键值对集合。

// Object
const obj = { name: 'John', age: 30 };

// Object对象转Map
const map = new Map(Object.entries(obj));

在上述代码中,我们使用Object.entries将Object对象转换为键值对集合,并将其传入Map的构造函数中来创建一个新的Map实例。

七、小标题:从DOM转Object对象

在Web开发中,我们通常需要从DOM树中获取数据,并将其转换为Object对象。在现代浏览器中,可以使用FormData对象轻松实现该功能。

const form = document.querySelector('form');
const formData = new FormData(form);
const obj = Object.fromEntries(formData.entries());

在上述代码中,我们首先获取了一个form元素,然后使用FormData将其转换为一个键值对集合。最后使用Object.fromEntries将键值对集合转换为Object对象。

八、小标题:选取

在实际开发过程中,我们可能需要根据具体场景选择不同的从Object转换为实体的方法。

如果要求转换速度比较快,可以选择从Object转对象或从Object强转对象。如果要求转换后的数据具有较高的可读性,可以选择从Object转实体或从Object强转实体。如果需要将Object对象转换为可迭代的数据结构,可以选择从Object对象转Map。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/156914.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-18 01:59
下一篇 2024-11-18 01:59

相关推荐

  • 面向对象编程、类和对象

    面向对象编程(Object-Oriented Programming, OOP)是一种编程方法,它将现实世界中的事物抽象为对象(Object),对象的属性和方法被封装成类(Clas…

    编程 2025-04-29
  • 全能编程开发工程师必知——DTD、XML、XSD以及DTD参数实体

    本文将从大体介绍DTD、XML以及XSD三大知识点,同时深入探究DTD参数实体的作用及实际应用场景。 一、DTD介绍 DTD是文档类型定义(Document Type Defini…

    编程 2025-04-29
  • Mapster:一个高性能的对象映射库

    本文将深入介绍furion.extras.objectmapper.mapster,一个高性能的对象映射库,解释它是如何工作的以及如何在你的项目中使用它。 一、轻松地实现对象之间的…

    编程 2025-04-28
  • Python返回对象类型

    Python是一种动态、解释型、高级编程语言。Python是一种面向对象的语言,即所有的一切都是一个对象。 一、基本类型 Python中的基本类型有整数int、浮点数float、布…

    编程 2025-04-28
  • Python中通过对象不能调用类方法和静态方法的解析

    当我们在使用Python编写程序时,可能会遇到通过对象调用类方法和静态方法失败的问题,那么这是为什么呢?接下来,我们将从多个方面对这个问题进行详细解析。 一、类方法和静态方法的定义…

    编程 2025-04-27
  • Python内置函数——查看对象内存

    本文将介绍Python内置函数中,在开发中查看对象内存的相关函数。 一、id()函数 id()函数是Python内置函数,用于返回对象的唯一标识符,也就是对象在内存中的地址。 nu…

    编程 2025-04-27
  • 解决ERP运行时错误429:ActiveX不能创建对象 DAO350

    ERP运行时错误429是由于“ActiveX不能创建对象”而引发的。这种错误通常是由于您在尝试访问Microsoft Access数据库时缺少了必要的组件。 一、安装并注册DAO库…

    编程 2025-04-27
  • Linux sync详解

    一、sync概述 sync是Linux中一个非常重要的命令,它可以将文件系统缓存中的内容,强制写入磁盘中。在执行sync之前,所有的文件系统更新将不会立即写入磁盘,而是先缓存在内存…

    编程 2025-04-25
  • 神经网络代码详解

    神经网络作为一种人工智能技术,被广泛应用于语音识别、图像识别、自然语言处理等领域。而神经网络的模型编写,离不开代码。本文将从多个方面详细阐述神经网络模型编写的代码技术。 一、神经网…

    编程 2025-04-25
  • Linux修改文件名命令详解

    在Linux系统中,修改文件名是一个很常见的操作。Linux提供了多种方式来修改文件名,这篇文章将介绍Linux修改文件名的详细操作。 一、mv命令 mv命令是Linux下的常用命…

    编程 2025-04-25

发表回复

登录后才能评论