如何用键值对照两个数组,并生成一个包含合并元素的新数组?
如何根据键值对照两个数组形成新数组?
问题描述:
给定两个数组 a 和 b,其中 a 数组的元素包含 id、key 和 value 属性,b 数组的元素包含 id 和一个键值对。需要找到 a 和 b 数组中 key 值相同的元素,并将其合并为一个新的数组。
期望输出:
[{id:3,key1:'sdf',key:'key1',value:'ggg'},{id:4,key2:'sdfdff',key:'key2',value:'cccc'}]
解决方案:
var a = [{id:1,key:'key1',value:'ggg'},{id:2,key:'key2',value:'cccc'}] var b = [{id:3,key1:'sdf'},{id:4,key2:'sdfdff'}] function getData(a, b) { var list = b.map(item => { var obj = a.find(i => Object.keys(item).includes(i.key)) || {} return {...obj, ...item} }) return list } var c = getData(a, b) console.log(c)
在 getData 函数中:
- 使用 map 函数对 b 数组的每个元素进行迭代。
- 对于每个元素 item,使用 find 函数在 a 数组中找到一个元素 i,其中 item 的 key 值是 i.key 的子字符串。
- 将找到的元素 obj 与 item 合并,形成新的对象。
- 将合并后的对象添加到 list 数组中。
- 返回 list 数组。
这样,我们可以将 a 数组中与 b 数组的 key 值相同的元素合并,形成一个新的数组 c。
以上就是如何用键值对照两个数组,并生成一个包含合并元素的新数组?的详细内容,更多请关注其它相关文章!