Déclaration et ordre d'évaluation des fonctions JavaScript
Lorsque vous travaillez avec des fonctions JavaScript, il est crucial de comprendre la distinction entre les déclarations et expressions de fonctions et leur impact sur l'ordre d'exécution. Cela peut être illustré en examinant quatre exemples :
// 1 (function() { setTimeout(someFunction1, 10); var someFunction1 = function() { alert('here1'); }; })(); // 2 (function() { setTimeout(someFunction2, 10); function someFunction2() { alert('here2'); } })(); // 3 (function() { setTimeout(function() { someFunction3(); }, 10); var someFunction3 = function() { alert('here3'); }; })(); // 4 (function() { setTimeout(function() { someFunction4(); }, 10); function someFunction4() { alert('here4'); } })();
Le premier exemple ne fonctionne pas en raison de l'ordre de compilation et d'exécution. En JavaScript, le code est compilé en deux phases : compilation et exécution.
Phase 1 : Compilation
Lors de la compilation, des variables sont créées. Dans l'exemple 1, la variable someFunction1 est déclarée après l'appel setTimeout. Par conséquent, lorsque le compilateur rencontre someFunction1 dans l'argument setTimeout, il ne peut pas trouver la variable.
Phase 2 : Exécution
Lors de l'exécution, l'interpréteur transmet la valeur de someFunction1 pour définirTimeout. Puisque la variable someFunction1 n'est toujours pas définie, l'interpréteur ne parvient pas à exécuter la fonction.
En revanche, les exemples 2, 3 et 4 fonctionnent tous car soit la déclaration de fonction est définie avant l'appel setTimeout (exemple 2), ou une fonction anonyme est transmise à setTimeout (Exemple 3), ou une référence à la fonction déclarée est utilisée (Exemple 4).
Déclarations de fonction vs expressions de fonction
Comprendre la différence entre les déclarations de fonction et les expressions est essentiel. Les déclarations de fonction (comme dans l'exemple 2) sont analysées lors de la compilation, tandis que les expressions de fonction (comme dans les exemples 1 et 3) sont évaluées lors de l'exécution. Cette différence peut impacter l'accès aux variables et l'ordre dans lequel le code est exécuté.
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!