Heim > Web-Frontend > js-Tutorial > Warum werden zwei leere JavaScript-Objekte nicht als gleich verglichen?

Warum werden zwei leere JavaScript-Objekte nicht als gleich verglichen?

Linda Hamilton
Freigeben: 2024-12-04 01:59:11
Original
905 Leute haben es durchsucht

Why Do Two Empty JavaScript Objects Not Compare as Equal?

Warum sind zwei identische Objekte nicht identisch miteinander?

In JavaScript der Gleichheitsoperator (==) und der strikte Gleichheitsoperator (===) werden zum Vergleichen von Werten verwendet. Beim Vergleichen von Objekten verhalten sich diese Operatoren jedoch anders als erwartet.

Beachten Sie den folgenden Code:

var a = {};
var b = {};

console.log(a == b); // returns false
console.log(a === b); // returns false
Nach dem Login kopieren

Dieser Code protokolliert für beide Ausdrücke „false“, obwohl a und b beides sind leere Objekte. Warum ist das so?

Der Hauptunterschied zwischen regulärer (==) und strikter (===) Gleichheit besteht darin, dass der strikte Gleichheitsoperator die Typkonvertierung deaktiviert. Da a und b beide Objekte sind, spielt die Art des Gleichheitsoperators in diesem Fall keine Rolle.

Unabhängig vom verwendeten Gleichheitsoperator werden Objektvergleiche nur dann als wahr ausgewertet, wenn Sie dasselbe exakte Objekt vergleichen . Mit anderen Worten, gegeben var a = {}, b = a, c = {};, a == a, a == b, aber a != c.

Zwei verschiedene Objekte (auch wenn sie null oder die gleichen genauen Eigenschaften haben) werden niemals gleich sein. Um die Gleichheit der Eigenschaften zweier Objekte zu vergleichen, können Sie die Methode Object.is() oder den in der bereitgestellten Antwort beschriebenen Ansatz verwenden.

Das obige ist der detaillierte Inhalt vonWarum werden zwei leere JavaScript-Objekte nicht als gleich verglichen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage