Heim > Web-Frontend > js-Tutorial > Warum ist `${\'h.className = h.className ? \'error\': \'error\'}` funktioniert in JavaScript nicht wie erwartet?

Warum ist `${\'h.className = h.className ? \'error\': \'error\'}` funktioniert in JavaScript nicht wie erwartet?

Barbara Streisand
Freigeben: 2024-10-30 04:34:28
Original
736 Leute haben es durchsucht

Why does `${'h.className  = h.className ? ' error' : 'error'}` not work as expected in JavaScript?

Fehlerbehebung bei der Priorität ternärer Operatoren in JavaScript

Der ternäre Operator von JavaScript ist ein leistungsstarkes Werkzeug für bedingte Zuweisungen, aber es kann schwierig sein, seine Priorität zu verstehen. Dieser Artikel konzentriert sich auf ein bestimmtes Szenario, in dem der ternäre Operator mit = kombiniert wird.

Das Problem verstehen

Bedenken Sie den folgenden Codeausschnitt:

h.className += h.className ? ' error' : 'error'
Nach dem Login kopieren

Auf den ersten Blick scheint der Code den aktuellen Wert von h.className basierend auf der ternären Bedingung entweder mit „error“ oder „error“ zu verketten. Allerdings kann diese Interpretation zu Fehlern führen.

Richtige Interpretation

Das Problem liegt in der Priorität der Operatoren. In JavaScript hat der Operator eine höhere Priorität als der ternäre Operator. Das bedeutet, dass der obige Ausdruck wie folgt ausgewertet wird:

h.className = h.className + (h.className ? ' error' : 'error')
Nach dem Login kopieren
Nach dem Login kopieren

Lösung

Um sicherzustellen, dass der ternäre Operator korrekt angewendet wird, sollte der Code wie folgt geschrieben werden:

h.className = h.className + (h.className ? ' error' : 'error')
Nach dem Login kopieren
Nach dem Login kopieren

Dadurch wird sichergestellt, dass der ternäre Operator vor der Verkettung mit h.className ausgewertet wird.

Zusätzliche Überlegungen

Das ist wichtig zu beachten h.className = ' error' ist ebenfalls gültig, aber nicht so präzise wie der aktualisierte Code. Der =-Operator gilt nur für h.className, während der aktualisierte Code das Ergebnis der ternären Bedingung explizit mit h.className verkettet.

Fazit

Das Verständnis der Operatorpriorität ist von entscheidender Bedeutung für Korrekten JavaScript-Code schreiben. Durch die Klärung der Vorrangregeln für den ternären Operator und den =-Operator bietet dieser Artikel eine Lösung für eine häufige Herausforderung, die bei der Verwendung bedingter Zuweisungen in JavaScript auftritt.

Das obige ist der detaillierte Inhalt vonWarum ist `${\'h.className = h.className ? \'error\': \'error\'}` funktioniert in JavaScript nicht wie erwartet?. 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