如何用键值对照两个数组,并生成一个包含合并元素的新数组?

如何用键值对照两个数组,并生成一个包含合并元素的新数组?

如何根据键值对照两个数组形成新数组?

问题描述:

给定两个数组 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。

以上就是如何用键值对照两个数组,并生成一个包含合并元素的新数组?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2804881.html

(0)
上一篇 2025年3月8日 22:00:09
下一篇 2025年3月8日 22:00:16

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论