Maison >interface Web >js tutoriel >Comment le placement des accolades et l'insertion d'un point-virgule affectent-ils les résultats du code JavaScript ?

Comment le placement des accolades et l'insertion d'un point-virgule affectent-ils les résultats du code JavaScript ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-10-22 21:05:29517parcourir

How Does Curly Brace Placement and Semicolon Insertion Affect JavaScript Code Results?

L'insertion d'un point-virgule et le placement d'accolades ont un impact sur les résultats

En JavaScript, le placement d'accolades peut modifier considérablement le résultat des extraits de code. Ceci est attribué à la présence de l'insertion automatique de point-virgule (ASI) dans JavaScript, une fonctionnalité qui insère des points-virgules à la fin de certaines instructions même si elles ne sont pas explicitement écrites.

Considérez l'exemple suivant où le placement du l'ouverture d'une accolade sur une nouvelle ligne conduit à des résultats inattendus :

<code class="javascript">function test() {
  return
  { /* <--- curly brace on new line */
    javascript: "fantastic"
  };
}</code>

Si l'accolade se trouve sur une nouvelle ligne, ASI insère un point-virgule à la fin de la première ligne, la séparant ainsi de la déclaration de l'objet . En conséquence, test() renverra undéfini et l'alerte affichera "non - c'est cassé : undéfini."

En revanche, lorsque l'accolade est sur la même ligne que l'instruction return, il n'y a pas point-virgule à insérer par ASI :

<code class="javascript">function test() {
  return { /* <---- curly brace on same line */
    javascript: "fantastic"
  };
}</code>

Dans ce cas, test() renvoie un objet avec la propriété javascript définie sur "fantastique", ce qui correspond au comportement attendu.

À éviter confusion potentielle et garantir la fonctionnalité souhaitée, il est essentiel d'utiliser explicitement des points-virgules lorsque cela est nécessaire et d'être conscient de l'impact de l'ASI sur l'exécution du code en JavaScript. Comprendre ces nuances peut éviter des résultats inattendus et faciliter le développement d'un code robuste.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn