登录
首页 >  文章 >  前端

如何通过数组元素相同值匹配组合新数组?

时间:2024-10-31 10:37:13 163浏览 收藏

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《如何通过数组元素相同值匹配组合新数组? 》,文章讲解的知识点主要包括,如果你对文章方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

如何通过数组元素相同值匹配组合新数组?

通过数组元素相同值匹配组合新数组

当前有两个数组 A 和 B,其中 A 数组包含 id 字段,而 B 数组包含 cid 字段和 des 字段。需要从这两个数组中提取特定数据并组合成一个新数组。

新数组包含的元素:

  • 当 A 数组的 id 与 B 数组的 cid 相等时,A 数组的 id
  • B 数组中 cid 与匹配 id 对应的所有其他字段

实现方法:

我们可以使用 JavaScript 中的 map() 方法来遍历 A 数组,然后使用 filter() 方法从 B 数组中过滤出与当前 A 数组元素 id 匹配的元素。通过此操作,我们可以组合出所需的元素并将其添加到新数组中。

let a = [{ id: 1 }, { id: 2 }];
let b = [{ cid: 1, des: "1" }, { cid: 1, des: "11" }, { cid: 2, des: "2" }];
let c = a.map(item => {
  return {
    ...item,
    list: b.filter(it => it["cid"] === item["id"])
  }
});

结果数组 c 将包含匹配 A 数组 id 的 B 数组元素:

[
  { id: 1, list: [{ cid: 1, des: "1" }, { cid: 1, des: "11" }] },
  { id: 2, list: [{ cid: 2, des: "2" }] }
]

今天关于《如何通过数组元素相同值匹配组合新数组? 》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>