JavaScript déte...LOGIN

JavaScript détermine les instructions if/else

if (条件 1)
  {
  当条件 1 为 true 时执行的代码;
  }
else if (条件 2)
  {
  当条件 2 为 true 时执行的代码;
  }
else
  {
  当条件 1 和 条件 2 都不为 true 时执行的代码;
  }

JavaScript utilise if () { ... } else { ... } pour le jugement conditionnel. Par exemple, pour afficher un contenu différent en fonction de l'âge, vous pouvez utiliser l'instruction if pour implémenter ce qui suit :

var age = 20;
if (age >= 18) { // 如果age >= 18为true,则执行if语句块
    alert('adult');
} else { // 否则执行else语句块
    alert('teenager');
}

L'instruction else est facultative. Si le bloc d'instructions ne contient qu'une seule instruction, vous pouvez omettre {} :

var age = 20;
if (age >= 18)
    alert('adult');
else
    alert('teenager');

Le danger d'omettre {} est que si vous souhaitez plus tard ajouter des instructions mais oubliez d'écrire {}, vous modifierez le if .. La sémantique de .else..., par exemple :

var age = 20;
if (age >= 18)
    alert('adult');
else
    console.log('age < 18'); // 添加一行日志
    alert('teenager'); // <- 这行语句已经不在else的控制范围了

La clause else du code ci-dessus est en fait uniquement responsable de l'exécution de console.log('age < 18');, l'alerte d'origine ("teenager") ; n'est plus dans la portée de contrôle de if...else..., il sera exécuté à chaque fois.

À l'inverse, une déclaration avec {} ne se trompera pas :

var age = 20;
if (age >= 18) {
    alert('adult');
} else {
    console.log('age < 18');
    alert('teenager');
}

C'est pourquoi nous recommandons de toujours écrire {}.

Jugement conditionnel multiligne

Si vous souhaitez juger les conditions plus en détail, vous pouvez utiliser une combinaison de plusieurs if...else. ..:

var age = 3;
if (age >= 18) {
    alert('adult');
} else if (age >= 6) {
    alert('teenager');
} else {
    alert('kid');
}

La combinaison ci-dessus de plusieurs if...else... est en fait équivalente à deux couches de if...else... :

var age = 3;
if (age >= 18) {
    alert('adult');
} else {
    if (age >= 6) {
        alert('teenager');
    } else {
        alert('kid');
    }

Mais nous écrivons habituellement sinon si ensemble, pour augmenter la lisibilité. Il n'y a pas de problème si le else omet ici {}, car il ne contient qu'une instruction if. Notez que le dernier else séparé ne doit pas être omis {}.

Veuillez noter que la fonction d'exécution des instructions if...else... est de choisir l'une des deux dans plusieurs instructions if...else..., si une certaine condition est vraie, la ultérieur Plus de jugement.

Essayez d'expliquer pourquoi le code suivant affiche adolescent :

'use strict';
var age = 20;
if (age >= 6) {
    alert('teenager');
} else if (age >= 18) {
    alert('adult');
} else {
    alert('kid');
}

Puisque la valeur de l'âge est 20, il satisfait en fait aux conditions âge >= 6 et âge >= 18 en même temps temps, ce qui est très important d'expliquer l'ordre des jugements conditionnels. Veuillez le corriger afin qu'il puisse afficher un adulte.

Que se passe-t-il si le résultat de l'énoncé du jugement conditionnel if n'est pas vrai ou faux ? Par exemple :

var s = '123';
if (s.length) { // 条件计算结果为3
    //
}

JavaScript traite null, indéfini, 0, NaN et chaîne vide'' comme faux, et toutes les autres valeurs comme vraies, donc le résultat du jugement conditionnel du code ci-dessus est vrai.

section suivante
<!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>if...else</title> <script type="text/JavaScript"> var myage =99;//赵红的年龄为99 if(myage<=44) {document.write("青年");} else if(myage<=59) {document.write("中年人");} else if(myage<=89) {document.write("老年人");} else {document.write("长寿老年人");} </script> </head> <body> </body> </html>
soumettreRéinitialiser le code
chapitredidacticiel