javascript - Comment fusionner les mêmes valeurs clés d'objets de tableau et placer les identifiants correspondants dans un tableau
ringa_lee
ringa_lee 2017-06-26 10:57:10
0
2
1522

Par exemple anciennes données :
var old = [

{
    id: 1,
    name: 'css',
    type: 'html'
},
{
    id: 2,
    name: 'css',
    type: 'html'
},
 {
    id: 3,
    name: 'javacript',
    type: 'code'
},
{
    id: 4,
    name: 'javacript',
    type: 'code'
}

]
La var souhaitée new = [

{
    id: [1,2],
    name: 'css',
    type: 'html'
},
 {
    id: [3,4],
    name: 'javacript',
    type: 'code'
},

]
J'espère fusionner des objets portant le même nom et mettre les identifiants correspondants dans un tableau

ringa_lee
ringa_lee

ringa_lee

répondre à tous(2)
滿天的星座
var hash = {};
var i = 0;
var res = [];
old.forEach(function(item) {
    var name = item.name;
    hash[name] ? res[hash[name] - 1].id.push(item.id) : hash[name] = ++i && res.push({
        id: [item.id],
        name: name,
        type: item.type
    })

});
console.log(JSON.stringify(res))
刘奇

Dans le tableau old ci-dessous

var old = [
    {
        id: 1,
        name: 'css',
        type: 'html'
    },
    {
        id: 2,
        name: 'css',
        type: 'html'
    },
     {
        id: 3,
        name: 'javacript',
        type: 'code'
    },
    {
        id: 4,
        name: 'javacript',
        type: 'code'
    }
]

Obtenez new

var new = [
    {
        id: [1,2],
        name: 'css',
        type: 'html'
    },
     {
        id: [3,4],
        name: 'javacript',
        type: 'code'
    }
]

Obtenu

var isEqual = (a, b) => a.name === b.name && b.type === b.type; 
var create = e => {
    e.id = [e.id]; 
    return e; 
}

var getNew = old => old.reduce((acc, cur) => {
    let hasItem = acc.some(e => {
        let temp = isEqual(e, cur); 
        if (temp) e.id.push(cur.id); 
        
        return temp; 
    });
    
    if (!hasItem) acc.push(create(cur))
    
    return acc; 
}, []);
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal