Qu'est-ce qui ne va pas avec les standards ?" />
Si vous développez vos connaissances en JavaScript et que vous vous demandez pourquoi ils ajouteraient des fonctions fléchées dans ECMAScript 2015 (ES6), vous n'êtes pas seul. En développant ma connaissance de la langue, de ses subtilités et de ses bizarreries, je me suis posé la même question. Dans cet article, je présenterai les différences, les avantages et les raisons pour lesquelles il a été ajouté et quand vous devriez l'utiliser.
Avant l'introduction des fonctions fléchées, les fonctions devaient être déclarées dans le format traditionnel comme ci-dessous :
function add(x, y) { return x + y; }
ou déclaré comme expression :
const addFunction = function add(x, y) { return x + y; }
avec l'introduction des fonctions fléchées, cela peut s'écrire :
const addFunction = (x,y) => x + y
À partir de l'exemple ci-dessus, nous pouvons facilement voir qu'en utilisant une fonction fléchée et en tirant parti de sa fonction de retour implicite, la fonction peut être rapidement refactorisée en une seule ligne. Le code résultant est plus concis, plus propre et plus facile à lire, ce qui permet un développement plus fluide et un débogage plus rapide.
Le runtime JavaScript hissera par défaut toutes les fonctions et déclarations de variables au sommet de leur portée lors de la création du contexte d'exécution. Par exemple, dans la portée globale, cela garantit que toutes les fonctions et variables déclarées seront disponibles pour toutes les fonctions appelées ultérieurement. Cependant, les fonctions fléchées ne sont jamais levées, permettant ainsi un meilleur contrôle sur l'emplacement précis de l'endroit où une fonction est exécutée et sur les variables auxquelles elle a accès.
Chaque fois qu'une fonction JavaScript est exécutée, elle crée un contexte d'exécution qui comprend des informations sur l'environnement dans lequel la fonction s'exécute, y compris la valeur de this. Alors qu'une fonction traditionnelle est exécutée dans son propre contexte, une fonction flèche héritera toujours du contexte de la fonction qui l'a appelée.
En utilisant le code ci-dessous :
class Person { constructor(){ this.name = "George"; this.greetings = ["Good Morning,","Hello!","Howdy!"]; } printGreetings(){ this.greetings.forEach(function print(greet){ console.log(`${greet} ${this.name}`); }); } } let person = new Person(); person.printGreetings();
nous obtiendrions une erreur disant : Impossible de lire la propriété 'forEach' de undefined, car bien que la fonction printGreetings soit dans le contexte de la classe Person et hérite de son contexte, néanmoins la fonction forEach (même si son une fonction JavaScript intégrée) s'exécute dans son propre contexte qui ne contient pas la propriété this.name, ce qui entraîne une recherche erreur.
Cependant, une fonction flèche ne s'exécutera jamais dans son propre contexte, et en réécrivant la fonction ci-dessus à l'aide d'une fonction flèche...
printGreetings(){ this.greetings.forEach((greet) => { console.log(`${greet} ${this.name}`); }); }
le résultat sera comme prévu
function add(x, y) { return x + y; }
Pour résumer les avantages des fonctions fléchées ; ils permettent un code plus court et plus concis ; offre un retour implicite du code du bloc fonctionnel ; ne remonte pas en haut du contexte d'exécution et conserve son emplacement exact dans le code ; enfin, ils héritent du contexte de la fonction qui l'a appelé sans exécuter son propre contexte, permettant une utilisation plus prévisible de ce mot-clé.
J'espère que cet article vous a aidé à mieux comprendre les différences et les avantages des fonctions traditionnelles par rapport à la fonction flèche, et vous a permis de faire un pas de plus dans votre parcours JavaScript !
Lectures complémentaires :
Blog Dmitri Pavlutin - Différences entre les fonctions fléchées et régulières
Documents de référence MDN - Fonctions fléchées
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!