ECMAScript 2021 中的 Object.fromEntries 解析及其应用场景

ECMAScript 2021 中的 Object.fromEntries 解析及其应用场景

在 ECMAScript 2019 中,我们已经看到了 Object.entries() 的出现,它可以将一个对象转化为一个键值对数组。而在 ECMAScript 2021 中,我们又迎来了一个新的方法 Object.fromEntries(),它可以将一个键值对数组转化为一个对象。本文将详细解析 Object.fromEntries() 的用法和应用场景。

Object.fromEntries() 的用法

Object.fromEntries() 方法可以接收一个键值对数组作为参数,然后将其转化为一个对象。它的语法如下:

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

其中 iterable 是一个可迭代对象,它的每个元素都是一个键值对数组,例如:

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

我们可以调用 Object.fromEntries() 方法将 iterable 转化为一个对象:

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

需要注意的是,如果 iterable 中有重复的键名,后面的键值会覆盖前面的键值。例如:

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

Object.fromEntries() 的应用场景

  1. 将 Map 转化为对象

在我们使用 Map 存储数据时,有时候需要将其转化为对象。这时候就可以使用 Object.fromEntries() 方法,例如:

----- --- - --- ------------- ---------- -------- ------------
----- --- - ------------------------
----------------- -- - ----- --------- ----- -------- -
  1. 将键值对数组转化为对象

在我们处理数据时,有时候需要将键值对数组转化为对象。这时候就可以使用 Object.fromEntries() 方法,例如:

----- -------- - --------- ---------- -------- -----------
----- --- - -----------------------------
----------------- -- - ----- --------- ----- -------- -
  1. 将对象转化为另一个对象

有时候我们需要将一个对象转化为另一个对象,这时候就可以使用 Object.fromEntries() 方法结合 Object.entries() 方法,例如:

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

在这个例子中,我们先使用 Object.entries() 方法将 obj1 转化为一个键值对数组,然后使用 map() 方法将每个值转化为大写,最后使用 Object.fromEntries() 方法将其转化为一个新的对象 obj2。

总结

Object.fromEntries() 方法可以将一个键值对数组转化为一个对象,它可以方便地将 Map 转化为对象,将键值对数组转化为对象,以及将一个对象转化为另一个对象。我们可以结合使用 Object.entries() 方法和 map() 方法来实现更加复杂的转化操作。

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


猜你喜欢

  • 了解 ES10 中的 BigInt:如何将字符串转换为 BigInt?

    在 JavaScript 中,数字类型被限制在 53 位以内,这意味着我们无法使用 JavaScript 内置的数字类型存储大整数。但是,在 ES10 中,我们可以使用 BigInt 类型来存储超出 ...

    7 个月前
  • RxJS 实战:配合 fromEvent 使用第三库监听事件

    RxJS 是一个强大的响应式编程库,它可以让我们更轻松地处理异步数据流。在前端开发中,我们通常需要监听 DOM 事件、WebSocket 消息、HTTP 请求等,RxJS 提供了一种优雅的方式来处理这...

    7 个月前
  • 如何在 Material Design 设计规范下让 App 增加趣味性?

    Material Design 设计规范是 Google 推出的一种设计语言,为移动设备和 Web 应用程序提供了一种美观、统一和易于使用的界面风格。然而,虽然 Material Design 的界面...

    7 个月前
  • ECMAScript 2021 中的 WeakRef 详解及应用场景

    在 ECMAScript 2021 中,新添加了一个弱引用(WeakRef)的特性,它可以用来解决 JavaScript 中的一些内存管理问题。本文将详细讲解 WeakRef 的概念、用法及应用场景。

    7 个月前
  • 使用 Headless CMS 和 Nuxt.js 构建静态网站的经验总结

    随着前端技术的不断发展,构建静态网站的方式也在不断地升级和改进。在这个过程中,Headless CMS 和 Nuxt.js 成为了一个非常流行的搭配方式。本文将介绍如何使用 Headless CMS ...

    7 个月前
  • JavaScript 状态管理之 Redux 详解

    引言 随着前端应用的复杂度不断提高,状态管理成为了一个重要的问题。Redux 是一个流行的 JavaScript 状态管理工具,它的思想和设计模式对于前端开发者来说都具有很大的指导意义。

    7 个月前
  • PWA 踩坑记:在 iOS Safari 中调用 Web Share API 时遇到的问题及解决方法

    前言 PWA(Progressive Web App)是一种新型的 Web 应用程序,它可以像本地应用程序一样运行,具有离线缓存、推送通知、添加到主屏幕等功能。其中,Web Share API 是 P...

    7 个月前
  • 使用 Koa.js 和 Passport.js 进行用户身份验证

    在 Web 应用程序中,用户身份验证是非常重要的一部分,它可以帮助我们保护用户的隐私和数据安全。在前端开发中,我们可以使用 Koa.js 和 Passport.js 这两个工具来实现用户身份验证。

    7 个月前
  • 在 Kubernetes 中使用 MongoDB 进行容器化数据管理

    前言 随着云计算和容器技术的快速发展,容器化部署已经成为现代应用程序开发的标准。Kubernetes 作为一款开源的容器编排工具,已经成为了容器化部署的事实标准。在这篇文章中,我们将介绍如何在 Kub...

    7 个月前
  • 在 Mocha 测试框架中使用 Babel 处理特定的测试文件

    在前端开发中,测试是一个非常重要的环节。而 Mocha 是一个非常流行的 JavaScript 测试框架,它可以帮助我们进行单元测试、集成测试等各种测试工作。而 Babel 则是一个非常流行的 Jav...

    7 个月前
  • Webpack4 打包 React 项目出现空白页面的问题及解决方案

    背景 Webpack 是一个强大的前端打包工具,它可以将多个 JavaScript 文件打包成一个或多个文件,使得前端项目可以更加高效地运行。而在使用 React 开发前端项目时,Webpack 也是...

    7 个月前
  • Custom Elements 实践:实现一个下拉刷新组件

    在前端开发中,组件化开发已经成为了一种趋势,因为它可以让我们更好地复用代码、提高开发效率、降低维护成本。在这篇文章中,我们将探讨如何使用 Custom Elements 技术来实现一个下拉刷新组件。

    7 个月前
  • ES10 中的 Object.freeze 方法:如何冻结对象?

    在前端开发中,我们经常需要处理对象。有时候,我们希望对象的属性不可更改,以保证数据的安全性和稳定性。在 ES5 中,我们可以使用 Object.freeze 方法来冻结对象。

    7 个月前
  • Express.js 中使用 JSON 格式进行数据交互的方法

    在前端开发中,数据交互是非常重要的一部分。而在 Express.js 中,使用 JSON 格式进行数据交互是非常常见的做法。本文将详细介绍在 Express.js 中使用 JSON 格式进行数据交互的...

    7 个月前
  • LESS 实现响应式标签云的基本思路

    标签云是网站中常见的一种展示标签的方式,通过不同大小、颜色等形式展示标签的重要程度和关联性。而响应式标签云则是在不同设备上自适应展示,以适应不同屏幕大小和分辨率的需求。

    7 个月前
  • ES2020:BigInts 和 BigInt

    在 JavaScript 中,数字一直是一个非常重要的类型,但是它有一个限制:它只能表示 2 的 53 次方以内的整数。这意味着在处理非常大的数字时,JavaScript 无法提供足够的精度。

    7 个月前
  • 遇到 Next.js 中的路由 404 问题该如何解决?

    背景 在使用 Next.js 进行开发时,我们经常会用到路由功能。但有时候我们会遇到路由 404 的问题,即当访问一个不存在的路由时,页面会显示 404。这个问题对于用户体验来说是非常不友好的,因此我...

    7 个月前
  • 如何在 Deno 中使用 CORS 解决跨域请求

    在前端开发中,跨域请求是一种常见的情况。由于浏览器的同源策略限制,跨域请求会受到限制,而无法直接访问其他域名下的资源。在 Deno 中,我们可以使用 CORS 来解决跨域请求的问题。

    7 个月前
  • Web Components 实现按需加载的技巧

    在现代web应用程序的开发中,按需加载(lazy loading)是一个重要的优化策略,它可以提高页面加载速度和性能。在前端开发中,Web Components 是一种流行的技术,它可以将页面组件化并...

    7 个月前
  • 在 Koa.js 中使用 CORS 解决跨域问题

    背景 在前端开发中,我们经常会遇到跨域问题。跨域问题是由于浏览器的同源策略所导致的,即浏览器只允许访问同一域名下的资源。如果我们需要访问不同域名下的资源,就会遇到跨域问题。

    7 个月前

相关推荐

    暂无文章