javascript – So führen Sie Objekte mit demselben Schlüsselwert in einem Array zusammen und fügen nach dem Zusammenführen unterschiedliche Werte in ein Array ein
伊谢尔伦
伊谢尔伦 2017-06-26 10:57:14
0
2
720

Anfangs
var alt = [

{
    id: 1,
    name: "first"
},
{
    id: 2,
    name: "first"
},
{
    id: 3,
    name: "second"
},
{
    id: 4,
    name: "second"
}

]
Das gewünschte Ergebnis
var new = [

{
    a: [1, 2],
    b: "first"
},
{
    a: [3, 4],
    b: "second"
}

]

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

Antworte allen(2)
学习ing

供参考

var new = Array.from(
  old.reduce((dict, item)=> {
    if (dict.has(item.name)) {
      dict.get(item.name).push(item.id)
    } else {
      dict.set(item.name, [item.id])
    }
    return dict
  }, new Map())
).map(item => ({a: item[1], b: item[0]}))
大家讲道理

原数组是

var old = [
    {
        id: 1,
        name: "first"
    },
    {
        id: 2,
        name: "first"
    },
    {
        id: 3,
        name: "second"
    },
    {
        id: 4,
        name: "second"
    }
]

期望得到

new = [
    {
        a: [1, 2],
        b: "first"
    },
    {
        a: [3, 4],
        b: "second"
    }
]

实现

var getNew = old => {
    let temp = old.reduce((acc, cur) => {
        if (acc[cur.name]){
            acc[cur.name].push(cur.id); 
        } else {
            acc[cur.name] = [cur.id]
        }
        return acc; 
    }, {});
    
    return Object.keys(temp).map(key => {
        return {
            a: temp[key],
            b: key
        }
    })
}

Just Run getNew(old)

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage