善用 ES10 中的 Object.fromEntries 方法

在前端开发中,我们经常需要将不同形式的数据转换为 JavaScript 对象。在 ES2019 中,新加了一个非常实用的方法,即 Object.fromEntries(),它可以帮助我们将键值对数组转换为对象。本文将详细介绍 Object.fromEntries() 的用法及其在前端实践中的应用,并提供示例代码。

Object.fromEntries() 简介

Object.fromEntries() 方法可以接受一个由键值对组成的数组,然后将其转换为一个新的对象。该方法可以代替常规的 for 循环或 Array.reduce() 方法实现一个对象的创建。

语法:Object.fromEntries(iterable)

参数:iterable 为一个可迭代对象,其中每个元素都是一个键值对数组。

返回值:一个新的对象,其中包含可迭代对象中的所有键值对。

示例代码:

----- ------- - --------- ------ ------- ---- ---------- ------
----- --- - ----------------------------
----------------- -- - ----- ----- ---- --- ------- --- -

Object.fromEntries() 的应用

以下是 Object.fromEntries() 在前端开发中的几个常见应用场景。

将 URLSearchParams 对象转换为对象

URLSearchParams 是浏览器原生 API,用于处理 URL 中的查询字符串。该 API 返回的对象虽然可以通过 get()/getAll()/has()/set()/append()/delete() 等方法获取/操作查询字符串,但是其原生格式不便于直接使用。

我们可以使用 Object.fromEntries() 方法将 URLSearchParams 对象转换为普通的对象,方便进行操作。

示例代码:

----- ----------- - --------------------------
----- ------ - --- -----------------------------
----- --- - ---------------------------
----------------- -- - ----- ----- ---- ----- ------- --- -

将 Map 转换为对象

Map 是 ES6 中新增的集合类型,其中存储的数据为键值对。有时候我们需要将 Map 转换为普通的对象,以方便进行操作。

示例代码:

----- --- - --- ------------- ------ ------- ---- ---------- -------
----- --- - ------------------------
----------------- -- - ----- ----- ---- --- ------- --- -

将数组对象转换为普通对象

有时候我们从后端获取数据时,返回的是一个数组对象,其中每个元素都是键值对数组。此时我们可以使用 Object.fromEntries() 方法将这个数组对象转换为普通的对象。

示例代码:

----- ---- - -
  --------- ------ ------- ---- ---------- ------
  --------- ------ ------- ---- ---------- ------
  --------- ------ ------- ---- ---------- -----
--
----- --- - -------------------------------- -- --- ------------
-----------------
--
-
  ---- - ----- ----- ---- --- ------- --- --
  ---- - ----- ----- ---- --- ------- --- --
  ---- - ----- ----- ---- --- ------- --- -
-
--

总结

Object.fromEntries() 方法可以帮助我们将键值对数组快速转换为对象,是一个非常实用的方法。除了上述几个常见场景外,该方法还可以用于在原有对象基础上进行修改。在实际开发中,我们可以结合自己的业务场景,灵活使用该方法,提高代码的效率和可读性。

示例代码:

----- --- - - ----- ----- ---- --- ------- --- --
----- ------ - ------------------------------------------------- ------- -- ----- ----- - -----
-------------------- -- - ----- ------ ---- --- ------- ---- -

希望本文对大家善用 Object.fromEntries() 方法有所帮助。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/653494ac7d4982a6eb960f62


猜你喜欢

  • Hapi.js+Redis 实现用户在线状态查询 - 解决 Redis 缓存重复读取问题

    Hapi.js+Redis 实现用户在线状态查询 - 解决 Redis 缓存重复读取问题 在实际开发中,我们经常需要查询用户是否在线,以及用户最近的活动时间。如果每个请求都去查询数据库,会造成数据库的...

    1 年前
  • 如何在 React Native 应用程序中使用 LESS?

    如何在 React Native 应用程序中使用 LESS? 在 React Native 开发中,使用 LESS 可以让你更好地管理样式,提高代码的可维护性。本文将详细介绍如何在 React Nat...

    1 年前
  • Custom Elements 中如何处理父组件与子组件通信

    在前端开发中,经常会遇到需要组件间通信的场景。而在使用 Custom Elements 进行组件开发时,如何处理父组件和子组件的通信是一个必须要掌握的技能。下面将介绍通过一些案例来详细探讨如何有效地处...

    1 年前
  • Koa2 中使用 Mongoose 连接 MongoDB 数据库

    前言 在 Web 开发中,数据库是非常重要的一个环节。由于前端技术的不断发展和进步,Web 开发越来越多地融合了前端和后端的技术,因此前端工程师也需要接触和了解数据库的知识和操作。

    1 年前
  • 使用 Deno 中的 fetch API 发送 HTTP 请求时如何正确地处理错误?

    在 Deno 中使用 fetch 函数来发送 HTTP 请求是一个非常方便的方式,但是在实际开发中,我们也需要正确地处理错误以避免不必要的问题。在本文中,我们将讨论如何在 Deno 中正确地处理 fe...

    1 年前
  • PWA 开发中使用 Intersection Observer API 监测元素的最佳实践

    近年来,PWA(Progressive Web App)的开发愈发成为前端界的热门话题。作为一种新型的 web 应用形态,PWA 通过利用浏览器和 Web 技术的最新能力,使得 web 应用具备了原生...

    1 年前
  • Android Material Design 中使用 SwipeRefreshLayout 实现加载更多的方法详解!

    Android Material Design 是 Google 推出的一套全新的视觉设计语言,它采用简洁、平面、直观的设计风格,使用户体验和应用程序功能更为统一一致。

    1 年前
  • 使用 Django 框架构建 RESTful API 的最佳实践

    随着 Web 技术的不断发展,目前前端开发中最为流行的一种方式是使用 RESTful API 与后端进行数据交互。而 Django 作为一款流行且上手容易的 Python Web 框架,也提供了强大的...

    1 年前
  • Cypress 测试中利用代理进行测试

    前言 Cypress 是一个基于浏览器的端到端测试框架,可用于自动化测试 Web 应用程序。使用 Cypress,您可以轻松地编写、运行和调试测试。其中,代理是 Cypress 中一个很有用的测试工具...

    1 年前
  • 使用 Node.js 读取 CSV 文件时遇到的问题及解决方式

    在前端开发中,我们经常需要处理 CSV 文件。而 Node.js 在处理 CSV 文件时,往往会遇到一些问题,而这些问题的解决方式也不是很明确。本文将详细讲述使用 Node.js 读取 CSV 文件时...

    1 年前
  • Mongoose 入门指南之 Schema 的错误处理

    在 Node.js 开发中,Mongoose 是一个非常流行的 MongoDB 驱动程序,它提供了一种非常方便的方式来操作 MongoDB 数据库。在 Mongoose 中,Schema 是其最重要的...

    1 年前
  • 如何避免 CSS Grid 元素溢出及居中布局

    前言 CSS Grid 是一种强大的布局方式,它能够让我们轻松地创建复杂的网格布局。然而,有时候我们不小心会遇到 CSS Grid 元素溢出的问题,又或者想要实现居中布局,但又不知道该如何下手。

    1 年前
  • 如何使用 ECMAScript 2016 的可选链式操作符解决对象属性不存在的问题

    在前端开发中,我们经常需要访问对象的属性和方法。但有时候在访问对象的属性或方法时,可能会遇到对象属性不存在的情况。在以前,我们通常需要使用 if 判断来避免这种情况的发生,但是这种做法会让代码变得臃肿...

    1 年前
  • Serverless 架构中的数据库设计需求分析

    随着近年来云计算及无服务器架构的兴起,前端开发工程师也逐渐开始关注并学习相关技术。而在使用 Serverless 架构时所涉及到的数据库设计问题,也成为了前端工程师需要解决的实际问题之一。

    1 年前
  • Tailwind CSS 使用教程:动画效果

    Tailwind CSS 是现代化的 CSS 框架,采用了命名类的方式来快速定位和设置样式。除此之外,Tailwind CSS 还内置了大量的基础样式和实用类,可以帮助开发者快速构建和定制网页样式。

    1 年前
  • 在 ES9 中使用异步参数和异步迭代器

    在现代化的 Web 应用中,异步函数和迭代器已经成为了 JavaScript 中不可或缺的要素。而在 ES9(ECMAScript 2018)中,异步函数和迭代器被进一步组合在一起,允许开发者使用异步...

    1 年前
  • React Native 0.43 升级升级遇到的问题及解决方案

    React Native(以下简称RN)是Facebook开发的两大主流Hybrid框架之一,提供了将JavaScript渲染为原生UI组件的能力,同时拥有较高的性能和开发效率。

    1 年前
  • 高性能 Web 服务开发:使用 Nginx 和 Lua 的技巧

    高性能 Web 服务开发:使用 Nginx 和 Lua 的技巧 在今天的互联网环境中,许多 Web 服务都需要高性能和高可用性。Nginx 是一个高性能的 Web 服务器,同时也可以作为一个反向代理服...

    1 年前
  • ES2020 中 String 新增方法 matchAll 引入及使用

    JavaScript 是一门面向对象、动态类型的编程语言,它一直在不断地发展和更新。ES2020 是 ECMAScript 的最新版本,其中包含了很多新的语法和功能,使得 JavaScript 更加强...

    1 年前
  • ES8 异步函数的错误处理详解

    在 JavaScript 编程中,异步函数是不可避免的部分。然而,处理异步错误并不总是那么容易。ES8 中引入了一种新的方式来处理异步错误,即异步函数。本文将深入探讨 ES8 异步函数的错误处理机制。

    1 年前

相关推荐

    暂无文章