如何判断两个数组元素是否相等并组合成新数组?

如何判断两个数组元素是否相等并组合成新数组?

判断数组元素是否相等,组合为新数组

给定两个数组 a 和 b,其中 a 数组包含对象,每个对象有 id、key 和 value 属性。b 数组也包含对象,但其属性名称不与 a 数组中的 key 属性相同。

目标是判断 a 数组中每个对象的 value 是否与 b 数组中某一对象的 key 相同。如果是,则将 a 数组和 b 数组中相匹配的元素合并到一个新数组中。

解决方案

可以使用 JavaScript map 函数结合 find 函数来解决这个问题。以下是步骤:

  1. 遍历 b 数组中的每个元素 item。
  2. 使用 find 函数在 a 数组中查找是否存在一个元素 i 满足 Object.keys(item) 包含 i.key。如果找到,则存储该元素到 obj 中。
  3. 使用扩展运算符将 obj 和 item 合并到一个新对象中。
  4. 将新对象添加到结果数组 list 中。

实现示例代码:

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)

以上就是如何判断两个数组元素是否相等并组合成新数组?的详细内容,更多请关注www.sxiaw.com其它相关文章!