javascript - 使用 javascript map 将嵌套数组扩展为行
问题描述
我怎样才能使用Array.prototype.map()
这个数据结构:
[
{text: "sometext", tags: ["t1", "t2", "t3"]},
{text: "sometext2", tags: ["t4", "t5", "t6"]}
]
进入这个数据结构?
[
{tag: "t1", text: "sometext"},
{tag: "t2", text: "sometext"},
{tag: "t3", text: "sometext"},
{tag: "t4", text: "sometext2"},
{tag: "t5", text: "sometext2"},
{tag: "t6", text: "sometext2"}
]
解决方案
您可以采用(即将推出)Array#flatMap
并映射内部数组。
var data = [{ text: "sometext", tags: ["t1", "t2", "t3"] }, { text: "sometext2", tags: ["t4", "t5", "t6"] }],
result = data.flatMap(({ text, tags }) => tags.map(tag => ({ tag, text })));
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
结果与Array#reduce
。
var data = [{ text: "sometext", tags: ["t1", "t2", "t3"] }, { text: "sometext2", tags: ["t4", "t5", "t6"] }],
result = data.reduce((r, { text, tags }) => [...r, ...tags.map(tag => ({ tag, text }))], []);
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
推荐阅读
- google-apps-script - 未使用 Google Apps 脚本在 Google 日历中添加事件描述
- gnuradio - 从源代码安装 GNU Radio 的问题
- angular - 嵌套值对象为空
- c# - 如何在微服务架构中创建流程或实现类似的设计
- javascript - React 功能组件在重新渲染时重新初始化本地函数和变量(React Hooks)
- postgresql - POSTGRESQL 触发问题
- ionic3 - 拨打 Ionic 3 的电话号码
- flutter - 为什么我的 Flutter 自定义 ScrollPhysics 会破坏 Scrollable 中的 GestureDetectors?
- d3.js - D3 - 在条形图上绘制箭头以反映数据
- java - 根据 logback-spring.xml 中的 springProfiles[dev, stg, prod] ,如何激活命令行中传递的相应 spring 配置文件