HTML: Markup language
CSS: Styling language
JavaScript: Scripting language
Web APIs: Programming interfaces
All web technology
Learn web development
Discover our tools
Get to know MDN better
Dieser Inhalt wurde automatisch aus dem Englischen übersetzt, und kann Fehler enthalten. Erfahre mehr über dieses Experiment.
View in English Always switch to English
Diese Funktion ist gut etabliert und funktioniert auf vielen Geräten und in vielen Browserversionen. Sie ist seit Juli 2015 browserübergreifend verfügbar.
Die if...else Anweisung führt eine Anweisung aus, wenn eine angegebene Bedingung truthy ist. Wenn die Bedingung falsy ist, wird eine andere Anweisung im optionalen else-Zweig ausgeführt.
if...else
else
function testNum(a) { let result; if (a > 0) { result = "positive"; } else { result = "NOT positive"; } return result; } console.log(testNum(-5)); // Expected output: "NOT positive"
if (condition) statement1 // With an else clause if (condition) statement1 else statement2
condition
Ein Ausdruck, der als entweder truthy oder falsy angesehen wird.
statement1
Anweisung, die ausgeführt wird, wenn condition truthy ist. Kann jede Anweisung sein, inklusive weiterer verschachtelter if-Anweisungen. Um mehrere Anweisungen auszuführen, verwenden Sie eine Block-Anweisung ({ /* ... */ }), um diese Anweisungen zu gruppieren. Um keine Anweisungen auszuführen, verwenden Sie eine leere-Anweisung.
if
{ /* ... */ }
statement2
Anweisung, die ausgeführt wird, wenn condition falsy ist und der else-Zweig existiert. Kann jede Anweisung sein, inklusive Block-Anweisungen und weiterer verschachtelter if-Anweisungen.
Mehrere if...else-Anweisungen können verschachtelt werden, um einen else if-Zweig zu erstellen. Beachten Sie, dass es in JavaScript kein elseif (in einem Wort) Schlüsselwort gibt.
else if
elseif
if (condition1) statement1 else if (condition2) statement2 else if (condition3) statement3 // … else statementN
Um zu sehen, wie dies funktioniert, würde es bei korrekter Einrückung der Verschachtelung so aussehen:
if (condition1) statement1 else if (condition2) statement2 else if (condition3) statement3 // …
Um mehrere Anweisungen innerhalb eines Zweigs auszuführen, verwenden Sie eine Block-Anweisung ({ /* ... */ }), um diese Anweisungen zu gruppieren.
if (condition) { statements1 } else { statements2 }
Das Nichtverwenden von Blöcken kann zu verwirrendem Verhalten führen, insbesondere wenn der Code manuell formatiert wird. Zum Beispiel:
function checkValue(a, b) { if (a === 1) if (b === 2) console.log("a is 1 and b is 2"); else console.log("a is not 1"); }
Dieser Code sieht harmlos aus – allerdings wird das Ausführen von checkValue(1, 3) "a is not 1" protokollieren. Dies liegt daran, dass im Fall von dangling else der else-Zweig mit dem nächstgelegenen if-Zweig verbunden wird. Der obige Code würde bei korrekter Einrückung folgendermaßen aussehen:
checkValue(1, 3)
Im Allgemeinen ist es eine gute Praxis, immer Block-Anweisungen zu verwenden, insbesondere bei Code, der verschachtelte if-Anweisungen enthält.
function checkValue(a, b) { if (a === 1) { if (b === 2) { console.log("a is 1 and b is 2"); } } else { console.log("a is not 1"); } }
Verwechseln Sie nicht die primitiven Boolean-Werte true und false mit der Truthyness oder Falsyness des Boolean-Objekts. Jeder Wert, der nicht false, undefined, null, 0, -0, NaN oder der leere String ("") ist, und jedes Objekt, einschließlich eines Boolean-Objekts, dessen Wert false ist, wird als truthy angesehen, wenn er als Bedingung verwendet wird. Zum Beispiel:
true
false
Boolean
undefined
null
0
-0
NaN
""
const b = new Boolean(false); if (b) { console.log("b is truthy"); // "b is truthy" }
if (cipherChar === fromChar) { result += toChar; x++; } else { result += clearChar; }
Beachten Sie, dass es keine elseif-Syntax in JavaScript gibt. Sie können es jedoch mit einem Leerzeichen zwischen else und if schreiben:
if (x > 50) { /* do something */ } else if (x > 5) { /* do something */ } else { /* do something */ }
Sie sollten fast nie ein if...else mit einer Zuweisung wie x = y als Bedingung haben:
x = y
if ((x = y)) { // … }
Denn im Gegensatz zu while Schleifen wird die Bedingung nur einmal ausgewertet, sodass die Zuweisung nur einmal durchgeführt wird. Der obige Code ist äquivalent zu:
while
x = y; if (x) { // … }
Was viel klarer ist. In dem seltenen Fall, dass Sie so etwas tun möchten, enthält die while-Dokumentation einen Abschnitt Verwendung einer Zuweisung als Bedingung mit unseren Empfehlungen.
JavaScript aktivieren, um diese Browser-Kompatibilitätstabelle anzuzeigen.
block
switch