Cet article partage avec vous le contenu de base de JS, ce pointeur et les points d'appel et de candidature associés. Les amis intéressés peuvent l'apprendre et s'y référer.
Dans des applications pratiques spécifiques, l'intérêt de ceci ne peut pas être déterminé lorsque la fonction est définie, mais est déterminé lorsque la fonction est exécutée. Selon l'environnement d'exécution, elle peut être grossièrement divisée en trois types :
1. Lorsque la fonction est appelée comme une fonction normale, cela pointe vers l'objet global
2 Lorsque la fonction est appelée comme une méthode de l'objet, cela pointe vers l'objet <.>
3. Lorsque la fonction est utilisée comme constructeur Lorsqu'elle est appelée, cela pointe vers l'objet nouvellement crééExemple :
window.name = 'myname'; function getName() { console.log(this.name); } getName(); //输出myname
Exemple deux :
var boy = { name: 'Bob', getName: function() { console.log(this.name); } } boy.getName(); //输出Bob
Exemple 3 :
function Boy(name) { this.name = name; } var boy1 = new Boy('Bob'); console.log(boy1.name); //输出Bob
Exemple quatre :
function Boy(name) { this.name = name; return { //返回一个对象 name: 'Jack' } } var boy1 = new Boy('Bob'); console.log(boy1.name); //输出Jack
Exemple cinq :
function Boy(name) { this.name = name; return 1; //返回非对象 } var boy1 = new Boy('Bob'); console.log(boy1.name); //输出Bob
appeler et Le rôle de apply
apply accepte deux paramètres. Le premier paramètre spécifie le pointeur de this dans le corps de la fonction. Le deuxième paramètre est un tableau ou un type de tableau utilisé pour transmettre le ParamètreExemple 1 :call Le nombre de paramètres transmis n'est pas fixe Comme pour apply, le premier paramètre est également utilisé pour spécifier la fonction. Le point dans le corps, à partir du deuxième paramètre, chaque paramètre est transmis tour à tour à la fonction appelée.
function getInfo() { console.log(this.name+' like '+arguments[0]+' and '+arguments[1]); } var boy1 = { name: 'Bob', age: 12 } getInfo.apply(boy1,['sing','swimming']); //输出Bob like sing and swimming
De plus, la plupart des navigateurs avancés implémentent également la méthode bind. La différence entre celle-ci et call and apply est que bind ne modifie que le. à l'intérieur de la fonction, cela pointe, mais il ne sera pas exécuté immédiatement, vous devez l'appeler explicitement.
function getInfo() { console.log(this.name+' like '+arguments[0]+' and '+arguments[1]); } var boy1 = { name: 'Bob', age: 12 } getInfo.call(boy1,'sing','shopping'); //输出Bob like sing and shopping
Function.prototype.bind = function(obj){ var self = this; return function(){ return self.apply(obj,arguments); } }; var obj = { name: 'Bob', age: 12 }; var func = function(){ console.log(this.name+' like '+arguments[0]+' and '+arguments[1]); }.bind(obj); func('sing','shopping');
J'ai perdu ceciDans Dans certains cas, le pointage de ceci sera perdu. À ce stade, nous devons utiliser call, apply et bind pour modifier le pointage de ceci.
Exemple 1 : Lorsque la méthode "getName" est appelée comme
propriétéde l'objet "boy", elle pointe vers l'objet "boy", et lorsqu'une autre variablefait référence Méthode "getName" ", car elle est appelée comme une fonction ordinaire, elle pointe vers la fenêtre d'objet globale
Exemple 2 : Même si la fonction est définie à l'intérieur de la fonction, si elle est appelé comme un objet ordinaire, cela pointe également vers l'objet fenêtrevar boy = { name: 'Bob', getName: function() { console.log(this.name); } } boy.getName(); //输出Bob var getBoyName = boy.getName; getBoyName(); //输出undefined
var boy1 = { name: 'Bob', age: 12, getInfo: function() { console.log(this.name); function getAge() { console.log(this.age); } getAge(); } } boy1.getInfo(); //Bob //undefined
Lecture recommandée :
Comment afficher les informations personnelles et changer le mot de passe dans vueAnalyse du principe de réactivité des données de VueCe 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!