如何通过数组元素相同值匹配组合新数组?
通过数组元素相同值匹配组合新数组
当前有两个数组 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" }] } ]
以上就是如何通过数组元素相同值匹配组合新数组?的详细内容,更多请关注其它相关文章!