Heim >Web-Frontend >js-Tutorial >So vergleichen Sie Objekte in Arrays in JavaScript effizient
In JavaScript ist es wichtig, Arrays mit Objekten effizient zu vergleichen, insbesondere wenn diese Objekte mehrere Eigenschaften enthalten und möglicherweise fehlende Werte aufweisen. Ein naiver Ansatz könnte darin bestehen, über jedes Array zu iterieren und einzelne Eigenschaften zu vergleichen. Für Fälle, in denen die Arrays jedoch auf eine bestimmte Größe (z. B. bis zu 8 Elemente) und Eigenschaftsanzahl beschränkt sind, gibt es eine elegantere Lösung.
Ein Ansatz besteht darin, Objektserialisierungstechniken zu nutzen. Es ist jedoch zu beachten, dass die Serialisierung allein nicht ausreicht, da die Reihenfolge der Objekteigenschaften die Ergebnisse beeinflusst. Daher ist eine robustere Methode erforderlich.
Betrachten Sie die folgende Funktion:
<code class="javascript">const objectsEqual = (o1, o2) => Object.keys(o1).length === Object.keys(o2).length && Object.keys(o1).every(p => o1[p] === o2[p]);</code>
Diese Funktion überprüft die Anzahl der Eigenschaften in beiden Objekten (Object.keys(o1).length) und vergleicht jeden Eigenschaftsschlüssel (p), um sicherzustellen, dass die entsprechenden Werte (o1[p]) gleich sind.
Beispielsweise bei folgenden Objekten:
<code class="javascript">const obj1 = { name: 'John', age: 33}; const obj2 = { age: 33, name: 'John' }; const obj3 = { name: 'John', age: 45 };</code>
Der Funktionsaufruf „objectsEqual(“ obj1, obj2) würde „true“ zurückgeben, da beide Objekte die gleichen Eigenschaften mit äquivalenten Werten haben, während „objectsEqual(obj1, obj3)“ aufgrund der unterschiedlichen Alterswerte „false“ zurückgeben würde.
Dieser Ansatz bietet eine prägnante und effiziente Möglichkeit dazu Vergleichen Sie Objekte innerhalb von Arrays und berücksichtigen Sie dabei fehlende Eigenschaftswerte und Eigenschaftsreihenfolge.
Das obige ist der detaillierte Inhalt vonSo vergleichen Sie Objekte in Arrays in JavaScript effizient. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!