Object.fromEntries和Object.entries的使用
object.entries()
转换一个object为array。但是,如果你想做相反的事情怎么办?不用再想了! 使用 Object.fromEntries()
来把array转换为object。const keyValuePair = [ ['cow', 'val1'], ['pig', 'val2'], ]; Object.fromEntries(keyValuePair); // { cow: 'val1', pig: 'val2' }
Object.fromEntries
我们先指出对象的解剖方法,对象是有一个键和一个值的东西。
const object = { key: 'value', };
如果我们想将某物转换为对象,我们需要传递具有这两个要求的东西:key
和 value
。
满足这些要求的参数有两种:
- 具有嵌套键值对的数组
- 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.fromEntries
与 Object.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: 'v1', broccoli: 'v2', carrot: 'v3' }; // Stuck in Array land const vegetarian = Object.entries(food).filter( ([key, value]) => key !== 'meat', ); // [ ["broccoli", "v2"], ["carrot", "v3"] ]
我们可以利用所有这些有用的数组方法,但仍然可以找回我们的对象,最后,从对象到对象的转换。
const food = { meat: 'v1', broccoli: 'v2', carrot: 'v3' }; // Yay, still in Object land const vegetarian = Object.fromEntries( Object.entries(food).filter(([key, value]) => key !== 'meat'), ); // { broccoli: 'v2', carrot: 'v3' }
浏览器支持
除了Internet Explorer,大多数主流浏览器都支持此方法 。
推荐教程:《JS教程》
以上就是Object.fromEntries和Object.entries的使用的详细内容,更多请关注其它相关文章!
上一篇: html5中文乱码怎么办
下一篇: 将头发烫染了一下而已
推荐阅读
-
SQL Server遍历表中记录的2种方法(使用表变量和游标)
-
sqlserver中delete、update中使用表别名和oracle的区别
-
Python使用poplib模块和smtplib模块收发电子邮件的教程
-
使用HTML5的File实现base64和图片的互转
-
PHP实现的汉字拼音转换和公历农历转换类及使用示例
-
ThinkPHP的cookie和session冲突造成Cookie不能使用的解决方法
-
Python 使用 attrs 和 cattrs 实现面向对象编程的实践
-
在Surface中IE浏览器触摸版和桌面版的设置使用技巧
-
基于B-树和B+树的使用:数据搜索和数据库索引的详细介绍
-
输入框的字数时时统计—关于 onpropertychange 和 oninput 使用