Maison > interface Web > js tutoriel > le corps du texte

Fonction flèche et ceci

PHPz
Libérer: 2024-07-31 01:28:24
original
827 Les gens l'ont consulté

Arrow function and this

Quel serait le résultat de ce foo.baz() ??

const foo = {
  bar: 10,
  baz: () => console.log(this.bar),
};


foo.baz();

Copier après la connexion

Cette fonction semble devoir fonctionner, mais si vous l'exécutez, le résultat sera « indéfini ». Pourquoi ?
En JavaScript, lorsque vous utilisez une fonction flèche, la fonction console.log(this.bar) recherchera une variable globale, car « this » mot-clé n'est pas lié à l'objet environnant mais à un objet global (fenêtre) dans le navigateur ou Environnement node.js.
Afin de résoudre ce problème, nous utilisons foo.bar ou modifions un peu un code et utilisons une expression de fonction régulière comme ceci

 baz: function () {
    console.log(this.bar);
  },

Copier après la connexion

Ou si nous devons utiliser une fonction fléchée, au lieu d'appeler une variable locale comme this.bar, nous pouvons utiliser le nom de l'objet et appeler foo.bar comme ceci.

 baz: () => console.log(foo.bar),

Copier après la connexion

Maintenant, la sortie sera correctement 10.

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:dev.to
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!