Heim > Web-Frontend > js-Tutorial > Wie kann der Kontext von „this' in JavaScript beibehalten werden, wenn setTimeout asynchron verwendet wird?

Wie kann der Kontext von „this' in JavaScript beibehalten werden, wenn setTimeout asynchron verwendet wird?

Patricia Arquette
Freigeben: 2024-10-24 18:25:19
Original
984 Leute haben es durchsucht

How to Preserve the Context of

setTimeout und das schwer fassbare „this“ in JavaScript

Bei der Verwendung der setTimeout-Funktion in JavaScript tritt häufig ein Problem auf, das unerwartete Verhalten von das Schlüsselwort „this“. Dies tritt auf, wenn eine Methode, die einen setTimeout-Aufruf enthält, auf eine andere Methode verweist, die referenzierte Methode jedoch nach dem Timeout-Zeitraum undefiniert wird.

Dieses Problem ergibt sich aus der Funktionsweise von setTimeout. Wenn eine Funktion als Argument an setTimeout übergeben wird, geht der Kontext von „this“ innerhalb dieser Funktion verloren. Dies liegt daran, dass setTimeout die Funktion asynchron ausführt und zu diesem Zeitpunkt möglicherweise nicht mehr auf den ursprünglichen Kontext von „this“ zugegriffen werden kann.

Um dieses Problem zu beheben, gibt es zwei gängige Lösungen:

1. Verwendung der bind()-Methode

Die bind()-Methode kann verwendet werden, um den Kontext von „this“ innerhalb der an setTimeout übergebenen Funktion beizubehalten. Durch das Anhängen von „.bind(this)“ an das Ende der Funktion bleibt der Kontext explizit erhalten, wie im folgenden Beispiel zu sehen ist:

setTimeout(function() {
    this.foo();
}.bind(this), 1000);
Nach dem Login kopieren

2. Pfeilfunktionen

Pfeilfunktionen binden „dies“ automatisch an den umgebenden Kontext. Daher sind keine zusätzlichen Schritte erforderlich, um den korrekten Kontext innerhalb der an setTimeout übergebenen Rückruffunktion beizubehalten:

setTimeout(() => {
    this.foo();
}, 1000);
Nach dem Login kopieren

Durch die Anwendung dieser Techniken auf das bereitgestellte Code-Snippet kann das Problem durch Ändern des Codes wie folgt gelöst werden:

test.prototype.method = function() {
    //method2 returns image based on the id passed
    this.method2('useSomeElement').src = "http://www.some.url";
    timeDelay = window.setTimeout(this.method.bind(this), 5000);
    //                                       ^^^^^^^^^^^ <- fix context
};
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann der Kontext von „this' in JavaScript beibehalten werden, wenn setTimeout asynchron verwendet wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage