Problem: Berechnen Sie die tiefen Unterschiede zwischen zwei tief verschachtelten JavaScript-Objekten und integrieren Sie Darstellungstechniken, um sie klar darzustellen Identifizieren Sie Änderungen.
Details: Gegeben sind zwei Objekte, oldObj und newObj ist ein benutzerdefinierter Diff-Algorithmus erforderlich, um die Unterschiede zwischen ihnen zu ermitteln, einschließlich Änderungen in Werten, Struktur und Array-Reihenfolge. Die Ausgabe sollte klar und JSON-serialisierbar dargestellt werden.
Lösung:
Eine benutzerdefinierte Klasse, deepDiffMapper, soll dieses Problem lösen:
var deepDiffMapper = function () { return { // Constants representing change types VALUE_CREATED: 'created', VALUE_UPDATED: 'updated', VALUE_DELETED: 'deleted', VALUE_UNCHANGED: 'unchanged', map: function(obj1, obj2) { // Algorithm for comparing objects return diff; }, compareValues: function (value1, value2) { // Logic for determining value changes return result; }, // Helper functions to identify object types ... } }();
Verwendung:
Um diese Klasse zu verwenden, einfach Rufen Sie die Map-Methode mit den beiden Objekten als Argumente auf:
var result = deepDiffMapper.map(oldObj, newObj);
Ausgabe:
Die Map-Methode gibt ein Objekt zurück, das die Unterschiede zwischen den beiden Eingabeobjekten darstellt. Die Schlüssel dieses Objekts entsprechen den Eigenschaften in newObj. Jeder Wert ist selbst ein Objekt mit den folgenden Eigenschaften:
Beispiel:
Angesichts der folgenden Eingabe Objekte:
var oldObj = { a: 'i am unchanged', b: 'i am deleted', e: { a: 1, b: false, c: null }, f: [1, { a: 'same', b: [{ a: 'same' }, { d: 'delete' }] }], g: new Date('2017.11.25') }; var newObj = { a: 'i am unchanged', c: 'i am created', e: { a: '1', b: '', d: 'created' }, f: [{ a: 'same', b: [{ a: 'same' }, { c: 'create' }] }, 1], g: new Date('2017.11.25') };
Die Kartenmethode würde das folgende Objekt zurückgeben, das die Unterschiede darstellt:
{ b: { type: 'deleted', data: undefined }, c: { type: 'created', data: 'i am created' }, e: { a: { type: 'updated', data: '1' }, b: { type: 'updated', data: '' }, d: { type: 'created', data: 'created' } }, f: { 1: { type: 'deleted', data: undefined }, 2: { b: { 1: { d: { type: 'deleted', data: undefined } }, 2: { c: { type: 'created', data: 'create' } } } } } }
Diese Darstellung zeigt deutlich die an den Objekten vorgenommenen Änderungen, wobei erstellte, aktualisierte und gelöschte Objekte hervorgehoben werden Eigenschaften.
Das obige ist der detaillierte Inhalt vonWie können Sie die tiefen Unterschiede zwischen zwei tief verschachtelten JavaScript-Objekten effektiv finden und darstellen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!