js数组对象合并,数组a与数组b合并成c的效果如何实现?

   let a = [1,2,3,4,5,6,7,10]
   let b = [{id:1,value:'a'},{id:2,value:'b'},{id:3,value:'c'},{id:4,value:'d'},{id:11,value:'e'}]
    //期待结果
    let c = [
      {
        id:1,
        value:'a'
      },
      {
        id:2,
        value:'b'
   },
      {
        id:3,
        value:'c'
      },
      {
        id:4,
        value:'d'
      },
      {
        id:5,
        value:null
      },
      {
        id:6,
        value:null
      },
      {
        id:7,
         value:null
      },
      {
        id:10,
        value:null
      },
    ]

数组a与数组b合并成c的效果如何实现,求指教?

阅读 1.7k
3 个回答
let a = [1,2,3,4,5,6,7,10]
let b = [{id:1,value:'a'},{id:2,value:'b'},{id:3,value:'c'},{id:4,value:'d'},{id:11,value:'e'}]
console.log(a.map(item => {
    return {
        id:item,
        ...(b.find(r => r.id==item)||{value:null})
    }
}))
a.map(id => ({id, value: b.find(o => o.id === id)?.value ?? null}))
let a = [1,2,3,4,5,6,7,10]
let b = [{id:1,value:'a'},{id:2,value:'b'},{id:3,value:'c'},{id:4,value:'d'},{id:11,value:'e'}]
  
const map = new Map(b.map((item) => [item.id,item.value]));

const result = a.map((item) => {
  return {
    id: item,
    value: map.get(item) || null
  }
})
console.log(result)
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
1 篇内容引用
推荐问题