Create JavaScript object from swaped key and value ES6 Map(从交换的键和值ES6映射创建JavaScript对象)
本文介绍了从交换的键和值ES6映射创建JavaScript对象的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有此ES6映射:
Map(6) {"Coratia" => 1, "Korea" =>, "Norway" => 2, "Munich" => 1, "Austrlia" => 1, ...}
我想交换键和值,使其如下所示:
{1 => "Coratia", 1 => "Korea", 2 => "Norway", 1 => "Munich", 1 => "Australia", ...}
推荐答案
这里您有一个使用CodyKnapp提到的想法的解决方案。它使用Array.reduce()生成value->key反转Map。
js"data-ide="false"data-console="true"data-babel="false">
let myMap = new Map([
["Cortia", 1],
["Korea", 1],
["Norway", 2]
]);
// Generate the reverse Map.
let res = [...myMap.entries()].reduce((acc, [k, v]) =>
{
acc.has(v) ? acc.set(v, acc.get(v).concat(k)) : acc.set(v, [k]);
return acc;
}, new Map());
// Log the new generated Map.
res.forEach((v, k) => console.log(`${k} => ${v}`));
.as-console {background-color:black !important; color:lime;}
.as-console-wrapper {max-height:100% !important; top:0;}
注意如注释中所述,您不能拥有将为多个不同的values复制相同的key的Map。
这篇关于从交换的键和值ES6映射创建JavaScript对象的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:从交换的键和值ES6映射创建JavaScript对象
基础教程推荐
猜你喜欢
- 原生拖动事件后如何获取 mouseup 事件? 2022-01-01
- 检查 HTML5 拖放文件类型 2022-01-01
- Bootstrap 模态出现在背景下 2022-01-01
- Bokeh Div文本对齐 2022-01-01
- fetch 是否支持原生多文件上传? 2022-01-01
- 如何添加到目前为止的天数? 2022-01-01
- 即使用户允许,Gmail 也会隐藏外部电子邮件图片 2022-01-01
- Fabric JS绘制具有活动形状的多边形 2022-01-01
- 在 contenteditable 中精确拖放 2022-01-01
- npm start 错误与 create-react-app 2022-01-01
