Maison >interface Web >js tutoriel >Existe-t-il une différence fonctionnelle entre `})()` et `}());` en JavaScript ?

Existe-t-il une différence fonctionnelle entre `})()` et `}());` en JavaScript ?

Patricia Arquette
Patricia Arquetteoriginal
2024-10-31 09:18:29416parcourir

Is There a Functional Difference Between `})()` and `}());` in JavaScript?

Syntaxe d'appel de fonctions en JavaScript : explorer les nuances

En JavaScript, la syntaxe d'appel de fonctions peut varier, ce qui soulève des questions sur leur fonctionnalité équivalence. Considérez les deux blocs de code suivants :

(function() {
    bar = 'bar';
    alert('foo');
})();

alert(bar);
(function() {
    bar = 'bar';
    alert('foo');
}());

alert(bar);

Les deux blocs de code alertent avec succès "foo" puis "bar". La seule différence notable semble être l'utilisation de })() et }()); à la fin. Alors, existe-t-il une distinction fonctionnelle entre ces deux approches ?

Fonctionnalité identique

Dans ce scénario particulier, aucune différence fonctionnelle n'existe entre les deux syntaxes. Les deux formulaires exécutent le code dans la fonction anonyme, attribuant la valeur « bar » à la variable bar et affichant les messages d'alerte comme prévu. Par conséquent, elles sont fonctionnellement équivalentes.

Quand des différences surviennent

Cependant, il existe des situations où les deux syntaxes produisent des résultats différents. Considérez les modifications suivantes :

new (function() {
    this.prop = 4;
})().prop;
new ( function() {
    return { Class: function() { } }; 
}() ).Class;

Dans le premier bloc de code, new est utilisé pour créer une nouvelle instance d'une classe et la propriété prop de cette instance est accessible. Cela renvoie la valeur 4.

En revanche, le deuxième bloc de code appelle new sur la propriété Class d'un objet renvoyé par une fonction. Étant donné que les parenthèses entourant l’appel de fonction se trouvent à l’intérieur des parenthèses extérieures, elles ne déclenchent pas de nouveau mais exécutent plutôt la fonction normalement. Ainsi, la propriété Class est instanciée à la place.

Conclusion

Dans la plupart des cas, })() et }()); sont interchangeables pour appeler des fonctions sans aucune implication fonctionnelle. Cependant, si new est utilisé avant les parenthèses ou si des opérations sont effectuées après les parenthèses, la syntaxe peut affecter le comportement du code. Il est crucial d'être conscient de ces nuances pour écrire du code JavaScript qui fonctionne comme prévu.

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