Portál AbcLinuxu, 12. května 2025 02:19

Dotaz: Javascript - Nefunkční this uvnitř funkce

13.10.2019 14:59 zacatecnickej
Javascript - Nefunkční this uvnitř funkce
Přečteno: 445×
Odpovědět | Admin
Ahoj, nemůžu zavolat metodu this.test(); uvnitř funkce v metodě show(). Neví někdo proč?

class Foo{
   test(){
      return 'bar';
   }
   show(){
      setTimeout ( function (){
         return this.test();
      },100);
}
}

var foo = new Foo();
var a = foo.show();
console.log(a);

Řešení dotazu:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

13.10.2019 15:26 Kit | skóre: 45 | Brno
Rozbalit Rozbalit vše Re: Javascript - Nefunkční this uvnitř funkce
Odpovědět | | Sbalit | Link | Blokovat | Admin
Ta anonymní funkce není součástí třídy a proto nemůže vidět její komponenty.
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
13.10.2019 15:44 zacatecnickej
Rozbalit Rozbalit vše Re: Javascript - Nefunkční this uvnitř funkce
A jde to opravit aby nebyla anonymní ta funkce ale zůstala funkční a viděla this?
Řešení 1× (BoneFlute)
13.10.2019 15:51 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Javascript - Nefunkční this uvnitř funkce
Odpovědět | | Sbalit | Link | Blokovat | Admin

Můžeš ji volat a voláš ji. Jenom ta funkce vůbec nic nedělá. Celý ten kód je minimálně dvojitý arcinesmysl. :-D

Zaprvé, ta inline funkce, kterou plánuješ tím časovačem (za 100 milisekund), nemá vůbec žádný efekt, zavolá test(), ten vrátí 'bar', inline funkce pak vrátí výsledek toho test()u, tedy zase 'bar', ale ten nikoho nezajímá, takže se ztratí a zapomene.

Zadruhé, to, co se tam snažíš vypsat pomocí console.log(), nemá žádnou spojitost s návratovou hodnotou funkce test() (jestli o tohle šlo). V proměnné a je návratová hodnota funkce show(), která je undefined, protože ve funkci show() není žádný return statement. Tady si můžeš přečíst, jak správně vracet hodnoty z asynchronních volání a setTimeout().

Zatřetí, v té inline funkci se nedá přistupovat k implicitnímu parametru this takhle přímo, protože taková inline funkce je (velmi zjednodušeně řečeno) buďto jiný objekt nebo úplně mimo kontext jakéhokoliv objektu, tj. proměnnou this nemá vůbec definovanou. Tohle je taky známá věc, stačí jenom hledat.

class Foo {
  constructor(message) {
    this.message = message;
  }
  show() {
    var _this = this;
    setTimeout (function() {
      console.log(_this.message);
    }, 1000);
  }
}

var foo = new Foo('blahblah');
foo.show();
console.log('Show scheduled!');
13.10.2019 15:56 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Javascript - Nefunkční this uvnitř funkce

Oprava: Ta metoda test() původně nebyla volaná vůbec (právě kvůli problému č. 3 s použitím this). To mi nějak uniklo.

13.10.2019 17:02 zacatecnickej
Rozbalit Rozbalit vše Re: Javascript - Nefunkční this uvnitř funkce
Ahoj, díky moc. Mě jde opravdu jenom o tuto funkci 'setTimeout' kterou mám v nějaké metodě a v té funkci se potřebuji dostat přímo na this, jde to i bez použítí var _this = this ; ?
setTimeout ( function (){
   this.test();
},100);
14.10.2019 00:47 Andrej | skóre: 51 | blog: Republic of Mordor
Rozbalit Rozbalit vše Re: Javascript - Nefunkční this uvnitř funkce

Tu inline funkci si lze představit jako metodu v oddělenén samostatném objektu, tj. i kdyby tam this byl definovaný, ukazoval by na jinou instanci jiného typu.

Nechápu, co míníš formulací „přímo na this“. Když si uložíš var _this = this, pak _this ukazuje přímo na ten původní objekt, na který ukazoval this. Je to reference. Jde jen o formalitu s uložením té reference v kontextu, který bude později dostupný dynamické inline funkci; nic přímého / nepřímého bych za tím nehledal.

18.10.2019 10:56 krab
Rozbalit Rozbalit vše Re: Javascript - Nefunkční this uvnitř funkce

Dobry den, pouzijte metodu bind:

 

setTimeout(function () {
   this.test();
}.bind(this), 100);

 

Aby Vas ukazkovy kod spravne fungoval, je nutne pouzit promise:

 

class Foo {
   test() {
      return 'bar';
   }

   show() {
      return new Promise(function(resolve, reject) {
         setTimeout (function () {
            resolve(this.test());
         }.bind(this), 100);
      }.bind(this));
   }
};

var foo = new Foo();
var a = foo.show();
a.then(console.log);
18.10.2019 18:55 crap
Rozbalit Rozbalit vše Re: Javascript - Nefunkční this uvnitř funkce
Konecne nekdo kdo umi slusne a vecne odpovedet

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.