Reiner JS-Ansatz : Meine Antwort basiert auf der Generierung einer Zeichenkette, die unabhängig von der Reihenfolge der Attribute den gleichen Wert liefert. Das Einstellungsobjekt kann verwendet werden, um die Groß- und Kleinschreibung und das Vorhandensein von Leerzeichen zu berücksichtigen. (Um zu vermeiden, dass ich den Fokus verliere, schließe ich diese Unterstützungsfunktionen nicht mit ein, ebenso wenig wie isObject, das wohl in jedem Utility-Set enthalten sein sollte).
Auch hier nicht gezeigt, aber um die String-Vergleichszeit zu reduzieren, wenn die Objekte groß sind und Sie den Vergleich beschleunigen möchten, könnten Sie auch die Strings hashen und Teilstrings vergleichen; dies würde nur bei sehr großen Objekten Sinn machen (und natürlich eine kleine Chance auf falsche Gleichheit).
Sie können dann einfach vergleichen genObjStr(obj1) ?= genObjStr(obj2)
function genObjStr(obj, settings) {
// Generate a string that corresponds to an object guarenteed to be the same str even if
// the object have different ordering. The string would largely be used for comparison purposes
var settings = settings||{};
var doStripWhiteSpace = defTrue(settings.doStripWhiteSpace);
var doSetLowerCase = settings.doSetLowerCase||false;
if(isArray(obj)) {
var vals = [];
for(var i = 0; i < obj.length; ++i) {
vals.push(genObjStr(obj[i], settings));
}
vals = arraySort(vals);
return vals.join(`,`);
} else if(isObject(obj)) {
var keys = Object.keys(obj);
keys = arraySort(keys);
var vals = [];
for(var key of keys) {
var value = obj[key];
value = genObjStr(value, settings);
if(doStripWhiteSpace) {
key = removeWhitespace(key);
var value = removeWhitespace(value);
};
if(doSetLowerCase) {
key = key.toLowerCase();
value = value.toLowerCase();
}
vals.push(value);
}
var str = JSON.stringify({keys: keys, vals: vals});
return str
} else {
if(doStripWhiteSpace) {
obj = removeWhitespace(obj);
};
if(doSetLowerCase) {
obj = obj.toLowerCase();
}
return obj
}
}
var obj1 = {foo: 123, bar: `Test`};
var obj2 = {bar: `Test`, foo: 123};
console.log(genObjStr(obj1) == genObjStr(obj1))
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