Heim > Web-Frontend > js-Tutorial > Wie erstelle und verwalte ich Versprechen mit setTimeout in JavaScript?

Wie erstelle und verwalte ich Versprechen mit setTimeout in JavaScript?

Linda Hamilton
Freigeben: 2024-12-06 00:27:11
Original
737 Leute haben es durchsucht

How to Create and Manage Promises Using setTimeout in JavaScript?

So erstellen Sie ein Versprechen aus setTimeout

Erstellen eines Basisversprechens für setTimeout

Um ein Versprechen zu erstellen, dass async nach dem Auslösen des setTimeout-Rückrufs zurückkehren kann, Wir können die setTimeout-Funktion in einen Promise-Konstruktor einschließen, wie im folgenden Snippet zu sehen ist:

<br>function setTimeoutReturnPromise(delay) {<br> return new Promise((resolve) => {</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">setTimeout(resolve, delay);
Nach dem Login kopieren
Nach dem Login kopieren

});
}

Diese Funktion verwendet eine Verzögerung als Argument und gibt ein Versprechen zurück. Das Versprechen wird nach Ablauf der angegebenen Verzögerung aufgelöst und der Rückruf der setTimeout-Funktion wird ausgeführt.

Versprechen des Versprechens mit Async verwenden

Nun unsere asynchrone Funktion kann die Funktion setTimeoutReturnPromise verwenden, um ein Versprechen zu erstellen, das zurückgegeben werden kann. Dadurch können wir die Methode then() verwenden, um Code auszuführen, nachdem der Rückruf setTimeout aufgerufen wurde:

<br>async(function() {<br> setTimeoutReturnPromise(5000).then( () => {</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">console.log("async called back");
Nach dem Login kopieren

});
});

Aktualisierung für ES2015 und darüber hinaus

Seit der Einführung von ES2015 und modernem JavaScript sind Versprechen zu integrierten Funktionen geworden. Die Syntax wurde vereinfacht, wie unten gezeigt:

<br>function later(delay) {<br> return new Promise((resolve) => {</p>
<div class="code" style="position:relative; padding:0px; margin:0px;"><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">setTimeout(resolve, delay);
Nach dem Login kopieren
Nach dem Login kopieren

});
}

Pfeilfunktionen verwenden und optionale Auflösungswertargumente kann der Code weiter komprimiert werden:

<br>const later = (delay, value) => new Promise(resolve => setTimeout(resolve, delay, value));<br>

Cancellable Promises (optional)

Wenn Sie die Zeitüberschreitung abbrechen möchten, können Sie ein Objekt mit einem Versprechen und einem Abbruch zurückgeben Methode:

<br>const later = (delay, value) => {<br> Let Timer = 0; zurückkehren {<br><br></p>};<div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">reject = _reject;
timer = setTimeout(resolve, delay, value);
Nach dem Login kopieren
};


Mit diesem Ansatz können Sie das Timeout abbrechen und das Versprechen mithilfe der Methode cancel() ablehnen.
get promise() { return promise; },
cancel() {
  if (timer) {
    clearTimeout(timer);
    timer = 0;
    reject();
    reject = null;
  }
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie erstelle und verwalte ich Versprechen mit setTimeout in JavaScript?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Vorheriger Artikel:Kann jQuery Tastendruckereignisse, einschließlich Sonderzeichen, zuverlässig simulieren? Nächster Artikel:Wie kann ich Ereignisse zur Größenänderung von Browserfenstern in JavaScript erkennen?
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
Aktuelle Ausgaben
verwandte Themen
Mehr>
Beliebte Empfehlungen
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage