Maison > interface Web > js tutoriel > Pourquoi une fonction JavaScript renvoie-t-elle un résultat non défini lorsqu'un saut de ligne se produit entre l'instruction Return et l'objet renvoyé ?

Pourquoi une fonction JavaScript renvoie-t-elle un résultat non défini lorsqu'un saut de ligne se produit entre l'instruction Return et l'objet renvoyé ?

Linda Hamilton
Libérer: 2024-10-24 09:08:29
original
1054 Les gens l'ont consulté

Why Does a JavaScript Function Return Undefined When a Line Break Occurs Between the Return Statement and Returned Object?

La fonction JavaScript renvoie un résultat non défini lorsqu'un saut de ligne se produit entre l'instruction Return et l'objet

En JavaScript, une fonction est censée renvoyer un objet lorsque l'instruction return est suivie directement de la définition de l'objet, comme le montre l'exemple suivant :

<code class="javascript">function foo1() {
  return { msg: "hello1" };
}</code>
Copier après la connexion

console.log(JSON.stringify(foo1())); // Sortie : { msg : "hello1" >
Cependant, si un saut de ligne sépare l'instruction return de la définition de l'objet, la fonction renvoie undefined, comme indiqué ci-dessous :

<code class="javascript">function foo2() {
 return
 { msg: "hello2" };
}</code>
Copier après la connexion

console.log (JSON.stringify(foo2())); // Sortie : non définie

Ce comportement se produit en raison du mécanisme d'insertion automatique de point-virgule (ASI) en JavaScript. ASI utilise des points-virgules dans certains contextes pour garantir la bonne exécution et l'interprétation du code. Dans le cas de foo2(), le saut de ligne est interprété comme un point-virgule, qui termine l'instruction return et introduit une instruction vide avant la définition de l'objet.

Solution

Pour résoudre ce problème, vous pouvez utiliser un opérateur de regroupement pour garantir que l'instruction return et la définition de l'objet sont évaluées comme une expression unique. Cela empêche ASI d'intervenir :

<code class="javascript">function foo2() {
  return ({ msg: "hello2" });
}</code>
Copier après la connexion

Considérations esthétiques

Bien qu'il soit important d'éviter les problèmes d'ASI, vous souhaiterez peut-être prendre en compte des facteurs esthétiques lors de l'écriture de votre code. Certains développeurs préfèrent regrouper les expressions pour plus de clarté ou pour souligner la structure de leur code. Par exemple :

<code class="javascript">return ([
  "ul",
  ["li",
    ["span", {class: "name"}, this.name],
    ["span", {id: "x"}, "x"]
  ]
]);</code>
Copier après la connexion

ou

<code class="javascript">function() {
  return (
    doSideEffects(),
    console.log("this is the second side effect"),
    1 + 1
  );
}</code>
Copier après la connexion

Dans ces exemples, l'opérateur de regroupement est utilisé pour garder les expressions organisées et pour améliorer la lisibilité.

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!

source:php
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal