web-dev-qa-db-fra.com

Comment trouver des différences entre deux tableaux d'objets JavaScript?

J'ai deux tableaux JavaScript orig (le tableau d'origine des objets) et update (le tableau d'orig des objets mis à jour) qui ont la même longueur et contiennent des objets.

Exemple:

var orig = [{enabled:"true", name:"Obj1", id:3},{enabled:"true", name:"Obj2", id:4}]; 

var update = [{enabled:"true", name:"Obj1", id:3}, {enabled:"true", name:"Obj2-updated", id:4}];

Le résultat devrait être: name:"Obj2-updated"

J'ai implémenté quelque chose mais il faut l'optimiser ...

for(var prop=0; prop<orig.length; prop++) {
  for(prop=0; prop<update.length; prop++) {
    if(orig[prop].enabled != update.enabled) { console.log(update.enabled) }
    if(orig[prop].name != update[prop].name) { console.log(update[prop].name) }
    if(orig[prop].id != update[prop].id) { console.log(update[prop].id) }
  }
}
14
Valip

Vous pouvez filtrer les clés et obtenir un résultat avec les clés mises à jour.

var orig = [{ enabled: "true", name: "Obj1", id: 3 }, { enabled: "true", name: "Obj2", id: 4 }],
    update = [{ enabled: "true", name: "Obj1", id: 3 }, { enabled: "true", name: "Obj2-updated", id: 4 }],
    difference = [];

orig.forEach(function (a, i) {
    Object.keys(a).forEach(function (k) {
        if (a[k] !== update[i][k]) {
            difference.Push({ id: update[i].id, key: k, value: update[i][k], index: i });
        }
    });
});

console.log(difference);

13
Nina Scholz

En supposant que les noms de propriété des deux soient identiques et que les valeurs ne soient que des primitives (aucun objet, tableau, etc.):

Object.keys( orig )
      .forEach( (key) => {
        if( orig[ key ] !== update[ key ] ) {
          console.log( update[key] );
        }
      });
6
Sirko

Vous pouvez utiliser une seule boucle pour parcourir les propriétés de l'objet d'origine et vérifier par rapport à l'objet mis à jour pour déterminer les propriétés modifiées.

var orig = {
  enabled: "true",
  name: "Obj1",
  id: 3
};

var update = {
  enabled: "true",
  name: "Obj1-updated",
  id: 3
};

for (var key in orig) {
  if (orig[key] !== update[key]) {
    console.log(key + ': ' + update[key]);
  }
}

3

Utilisez Object.keys pour parcourir votre objet. Quelque chose comme:

var orig = {
  enabled: "true",
  name: "Obj1",
  id: 3
};

var update = {
  enabled: "true",
  name: "Obj1-updated",
  id: 3
};

var diff = {};

Object.keys(orig).forEach(function(key) {
  if (orig[key] != update[key]) {
    diff[key] = update[key];
  };
})

console.log(diff);

3
tewathia

Vous pouvez utiliser une bibliothèque comme lodash ou Ramda pour le faire de manière concise. Dans le cas de Ramda, vous pouvez faire: R.difference(update, orig);

0
Barry G