查看原文
其他

你知道Object.entries(),但你还知道有Object.fromEntries()吗?

Dunizb 前端全栈开发者 2022-07-09

 object.entries() 转换一个object为array。但是,如果你想做相反的事情怎么办?不用再想了!使用 Object.fromEntries() 来把array转化为object 👏。

const keyValuePair = [
['cow', '🐮'],
['pig', '🐷'],
];
Object.fromEntries(keyValuePair);
// { cow: '🐮', pig: '🐷' }

Object.fromEntries

我们先指出对象的解剖方法,对象是有一个键和一个值的东西。

const object = {
key: 'value',
};

如果我们想将某物转换为对象,我们需要传递具有这两个要求的东西:keyvalue

满足这些要求的参数有两种:

  1. 具有嵌套键值对的数组
  2. Map对象

用Object.fromEntries将数组转为对象

这是带有键值对的嵌套数组

const nestedArray = [
['key 1', 'value 1'],
['key 2', 'value 2'],
];

当我们将 Object.fromEntries 应用于它时,我们可以从中获取对象。

Object.fromEntries(nestedArray);
// { key 1: "value 1", key 2: "value 2"}

用Object.fromEntries将Map转为对象

JavaScript ES6为我们带来了一个名为map的新对象,它与对象非常相似。

让我们创建新的Map对象

// 使用构造函数
const map = new Map([
['key 1', 'value 1'],
['key 2', 'value 2'],
]);
// 或者我们可以使用实例方法,"set"
const map = new Map();
map.set('key 1', 'value 1');
map.set('key 2', 'value 2');
// 结果
// Map(2) {"key 1" => "value 1", "key 2" => "value 2"}

现在,我们使用 Object.fromEntries 将Map转换为对象

Object.fromEntries(map);
// { key 1: "value 1", key 2: "value 2"}

Object.fromEntries与其他类型的类型错误

当你试图将其他数据类型传递到 Object.fromEntries 时,请小心,所有这些都会抛出一个错误 🚨

未捕获的类型错误(Uncaught TypeError)

确保只传递键值对 👍

Object.fromEntries vs Object.entries

Object.fromEntriesObject.entries 的效果相反。所以 Object. entries 将转换我们的数组并返回一个新的嵌套的键值对数组。而 Object.fromEntries 将把这个数组转回一个对象。

const object = { key1: 'value1', key2: 'value2' };
const array = Object.entries(object);
// [ ["key1", "value1"], ["key2", "value2"] ]
Object.fromEntries(array);
// { key1: 'value1', key2: 'value2' }

Object到Object的转换

如果你阅读了原始的TC39提案,这就是引入此新方法的原因。随着 Object.entries 的引入,没有一种简单的方法可以将结果转换回对象。

通常,当我们选择使用 Object.entries 时,是因为它使我们可以访问许多漂亮的数组方法,例如 filter。但是在完成转换之后,我们有点被该数组所困扰。

const food = { meat: '🥩', broccoli: '🥦', carrot: '🥕' };
// 😖 Stuck in Array land
const vegetarian = Object.entries(food).filter(
([key, value]) => key !== 'meat',
);
// [ ["broccoli", "🥦"], ["carrot", "🥕"] ]

我们可以利用所有这些有用的数组方法,但仍然可以找回我们的对象,最后,从对象到对象的转换 👏。

const food = { meat: '🥩', broccoli: '🥦', carrot: '🥕' };
// 😄 Yay, still in Object land
const vegetarian = Object.fromEntries(
Object.entries(food).filter(([key, value]) => key !== 'meat'),
);
// { broccoli: '🥦', carrot: '🥕' }

浏览器支持

除了Internet Explorer,大多数主流浏览器都支持此方法 👍。

前端大礼包新增课程了💯

新增课程《ES6零基础教学与解析彩票项目》,学习当下和未来大热技术!公众号中回复关键字:“前端大礼包”即可获取,不定期新增新课程,新增课程都会通知大家。



近期文章

5步使用JavaScript直接从前端发送电子邮件

Vue技巧 | 在Vue3中使元素在滚动视图时淡入

实战|如何使用JavaScript访问设备前后摄像头

仅3行核心CSS代码的rate评分组件

Vue 3教程(适用于Vue 2用户)

JavaScript vs Dart  两者之间的比较

a标签打开新标签页避免出现安全漏洞,请使用“noopener”

实战 | 使用TypeScript和ES模块发布Node模块

避免在单页应用程序中使用CORS,如何以及为什么?

测量函数的性能的简单方法及与其他方式对比

不要过度使用React.useCallback()

HTML页面生成器:使用JavaScript和Node创建CLI

Vue.js进阶必会,编写你的第一个Vue.js插件

从零开始使用JavaScript制作自己的命令行(CLI工具)

Vue.js中编写更好的v-for循环的6种技巧

如果对你有帮助,还可以在看、留言、转发,这是对作者最大的帮助。

您可能也对以下帖子感兴趣

文章有问题?点此查看未经处理的缓存