Lorsque la valeur de this est définie
En JavaScript, la valeur de this est déterminée par la manière dont une fonction est appelée. Il existe six façons principales de définir cela :
-
Appel de fonction normal : il est défini sur l'objet global (par exemple, une fenêtre dans un navigateur) ou non défini en mode strict.
-
Appel de méthode : ceci est défini sur l'objet sur lequel la méthode est appelée.
-
.apply() ou .call() : this est défini sur l'objet passé comme premier argument.
-
new Opérateur : Lorsqu'une fonction est appelée avec new, un nouvel objet est créé et celui-ci est défini sur cet objet.
-
.bind() : Crée une nouvelle fonction stub où celle-ci est liée à l'objet passé comme premier argument.
-
Fonction ES6 Fat Arrow : this est lié à la valeur lexicale de la portée englobante.
Le cas des fonctions de rappel
Dans votre exemple :
<code class="javascript">randomFunction(this.sumData.bind(this));</code>
Copier après la connexion
- this.sumData .bind(this) utilise .bind() pour lier ceci à l'objet obj.
- Par conséquent, lorsque randomFunction appelle la fonction de rappel, celle-ci est définie sur obj à cause de .bind().
- Si vous deviez échanger this.sumData.bind(this) avec callback(data), this à l'intérieur de randomFunction serait défini sur l'objet global (ou non défini en mode strict).
Ceci est car le rappel est passé comme référence à this.sumData.bind(this), mais lorsque randomFunction appelle le rappel, il le définit selon les règles d'un appel de fonction normal.
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!