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

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

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

当前有两个数组 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" }] }
]

以上就是如何通过数组元素相同值匹配组合新数组?的详细内容,更多请关注其它相关文章!