Bei Objekten (ohne Methoden) müssen wir prüfen, ob nested Objects
, Arrays
y primitive types
. Objekte können andere Objekte und Arrays haben (Arrays können auch andere Objekte und Arrays enthalten), daher können wir rekursive Funktionen wie unten verwenden: arrayEquals
prüft Arrays auf Gleichheit und equals
prüft die Gleichheit der Objekte:
function arrayEquals(a, b) {
if (a.length != b.length) {
return false;
}
for (let i = 0; i < a.length; i++) {
if (a[i].constructor !== b[i].constructor) {
return false;
}
if (a[i] instanceof Array && b[i] instanceof Array) {
if (!arrayEquals(a, b)) {
return false;
}
} else if (a[i] instanceof Object && b[i] instanceof Object) {
if (!equals(a[i], b[i])) {
return false;
}
} else if (a[i] !== b[i]) {
return false;
}
}
return true;
}
function equals(a, b) {
for (let el in a) {
if (b.hasOwnProperty(el)) {
if (a[el].constructor !== b[el].constructor) {
return false;
}
if (a[el] instanceof Array && b[el] instanceof Array) {
if (!arrayEquals(a[el], b[el])) {
return false;
}
} else if (a[el] instanceof Object && b[el] instanceof Object) {
if (!equals(a[el], b[el])) {
return false;
}
} else if (a[el] !== b[el]) {
return false;
}
} else {
return false;
}
}
return true;
}
Stellen Sie sich vor, Sie haben zwei Objekte:
let a = {
a: 1,
b: { c: 1, d: "test" },
c: 3,
d: [{ a: [1, 2], e: 2 }, "test", { c: 3, q: 5 }],
};
let b = {
a: 1,
b: { c: 1, d: "test" },
c: 3,
d: [{ a: [1, 2], e: 2 }, "test", { c: 3, q: 5 }],
};
Und hier unter Verwendung der oben genannten equals
können Sie zwei dieser Objekte wie folgt vergleichen:
if(equals(a, b)) {
// do whatever you want
}
5 Stimmen
Gehen Sie auch dieser Frage nach stackoverflow.com/q/1068834/1671639
55 Stimmen
Beachten Sie, dass auch in Java,
a.hashCode() == b.hashCode()
tut no bedeuten, dassa
ist gleichb
. Das ist eine notwendige, aber keine hinreichende Bedingung.7 Stimmen
Wenn Sie Objekte in Ihrem Code vergleichen MÜSSEN, dann haben Sie Ihren Code wahrscheinlich falsch geschrieben. Die bessere Frage könnte lauten: "Wie kann ich diesen Code so schreiben, dass ich keine Objekte vergleichen muss?"
0 Stimmen
Versuchen Sie objekt-gleich Paket.
13 Stimmen
@th317erd kannst du dich bitte erklären?...
3 Stimmen
@ElMac Ich kann nicht direkt für die Person sprechen, aber ich stimme mit der Aussage überein und mein Gedankengang ist, dass JS-Objekte sehr oft ziemlich groß sind. Sie haben selten etwas mit sehr wenigen Eigenschaften wie
person = { name: "fred", age: 42 }
. Wenn Sie das tun und nach der exakten Gleichheit suchen müssen, scheint das eine Verschwendung zu sein. Meistens haben Ihre einfachen Objekte immer noch eine Menge Eigenschaften - und eine davon ist entweder einzigartig oder Sie wollen, dass eine davon eindeutig ist, z.B. eine Art ID. Dann kann man danach suchen und braucht nicht zu prüfen, ob jedes einzelne Objekt übereinstimmt.0 Stimmen
Die meisten der Kommentatoren hier haben Recht, dass dies keine sehr gute Methode ist. Seit diesem Beitrag habe ich viel mit dieser Methode herumgespielt, mit unterschiedlichem Erfolg. Letztlich ist es nicht eine sehr gute Methode für den Objektvergleich, und die Menge an zusätzlichem Code erforderlich, um es zu arbeiten meist richtig macht es nicht wert (verwenden Sie einfach eine einfache tiefe Objekt Komparator statt)
0 Stimmen
Versuchen Sie
deep-equal
NPM-Paket0 Stimmen
jsben.ch/1uLAP <= Leistungsvergleich zwischen JSON.stringify und fast-deep-equal
2 Stimmen
Die Stufe 2 Datensatz- und Tupelvorschlag wird dies drastisch vereinfachen:
#{ x: 5, y: 7 } === #{ x: 5, y: 7 }
,#[ 4, #{ a: "hello", b: "world" }, 6, 10 ] === #[ 4, #{ b: "world", a: "hello" }, 6, 10 ]
.0 Stimmen
Dies ist ein Konzept, das als oberflächlicher Gleichheitsvergleich bezeichnet wird. Es wird dieses Problem lösen stackoverflow.com/a/70815902/12872199
0 Stimmen
Ich gebe hier wirklich eine ähnlich nette Antwort: stackoverflow.com/a/71173966/1919821