Comprendre la sémantique nuancée des fonctions au niveau des blocs dans ES6
L'introduction des fonctions au niveau des blocs dans ES6 a fait ressortir des complexités qui nécessitent une analyse approfondie examen. Malgré l'idée qu'ils suivent les règles de levage de blocs et de restriction de portée en mode strict, la disposition facultative des « extensions Web » crée des complexités supplémentaires.
Pour clarifier cette sémantique, considérez le tableau suivant, qui décrit le comportement de déclarations de fonctions au niveau du bloc dans diverses conditions :
Mode | Web Extensions | Visible Outside Block | Hoisted | TDZ |
---|---|---|---|---|
Non-Strict, No Extensions | No | Yes, as a var | Yes, to Function and Block | Undefined Before Block |
Strict, No Extensions | No | No | Yes, to Block | N/A |
| Non strict, avec extensions | Oui | Oui, en tant que var | Oui, pour fonctionner et bloquer | Non défini avant la déclaration de fonction |
| Strict, avec des extensions | Oui | Oui, en tant que var | Oui, pour bloquer | N/A |
La distinction clé réside dans le concept de « mode strict ». Dans le contexte des fonctions au niveau du bloc, le mode strict fait référence à la rigueur de la fonction (ou script) dans laquelle le bloc contenant la déclaration de fonction apparaît, pas la rigueur de la fonction lui-même.
En mode non strict avec des extensions web, une déclaration de fonction dans un bloc est considérée comme "saine" si son nom n'entre pas en conflit avec des paramètres formels ou des variables déclarées lexicalement. Dans de tels cas, une déclaration var supplémentaire est hissée dans la portée de la fonction englobante et l'objet fonction est affecté à cette variable lors de l'évaluation de la déclaration de fonction.
Ce comportement reflète la structure de code suivante :
function enclosing(...) { var compat₀ = undefined; { let compat₁ = function compat(…) { … }; compat₀ = compat₁; } }
Par conséquent, la fonction devient visible en dehors du bloc, semblable à une déclaration var. Cependant, une liaison supplémentaire au niveau du bloc existe dans le bloc.
En mode strict, quelles que soient les extensions Web, les fonctions au niveau du bloc sont hissées en haut du bloc et leur visibilité est restreinte au sein de ce bloc.
Il est crucial de noter que la sémantique susmentionnée ne se traduit pas toujours directement en implémentations pratiques. Les incohérences entre les implémentations d'ES6 ne sont pas rares, ce qui souligne l'importance de comprendre la spécification ES6 elle-même, quelles que soient les variations d'implémentation.
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!