Asynchrone JS ES6-Lösung

Asynchrone JS ES6-Lösung

Erste Verwendung der Callback-Funktion

​ Da es zu Beginn keine klare offizielle Spezifikation für js gab, gab es keine klare Spezifikation für die Parameter in den Rückruffunktionen, die in den in verschiedenen Bibliotheken von Drittanbietern gekapselten asynchronen Funktionen übergeben wurden, und die Bedeutung jedes Parameters war nicht klar, was die Verwendung unbequem machte.

Aber es gibt klare Vorgaben im Node

Rückrufmodus im Knoten:

1. Alle Rückruffunktionen müssen zwei Parameter haben, der erste Parameter gibt den Fehler an und der zweite Parameter gibt das Ergebnis an

2. Alle Rückruffunktionen müssen der letzte Parameter der Funktion sein

3. Alle Rückruffunktionen können nicht als Attribute erscheinen

es6 asynchrones Verarbeitungsmodell

Nach dem Erscheinen von Es6 wurden offiziell Spezifikationen für die asynchrone Verarbeitung und ein für alle asynchronen Szenarien geeignetes Verarbeitungsmodell vorgeschlagen. Das Modell hat:

  • Zwei Phasen: unruhig und gelassen.
  • Drei Zustände: Ausstehend, Gelöst, Abgelehnt
  • Wechseln Sie immer von der ungelösten Phase zur gelösten Phase. Der Status der gelösten Phase ändert sich nicht.

Nachdem sich die Aufgabe im Status „Aufgelöst“ befindet, ist möglicherweise eine nachfolgende Verarbeitung erforderlich.

  • Die nachfolgende Verarbeitung von aufgelösten thenable-Objekten nennen wir
  • Die Weiterverarbeitung von abgelehnten Catchables nennen wir

Auf dieses asynchrone Modell zugeschnittene API: Promise

So verwenden Sie Versprechen

Kopie

const task = neues Versprechen((lösen, ablehnen) => {     
    // Code für ausstehende Aufgabenphase // Sofort ausführen console.log("100-Meter-Langstreckenlauf starten");  
    setzeTimeout(() => {  
       wenn (Math.random() > 0,5) {  
           // Erfolg: Fertig // Bis zum Erfolg pushen resolve("finished");  
       } anders {  
           // Fehler: Beinbruch // Bis zum Fehler pushen reject("Beinbruch");  
       }  
    }, 1000)
});
task.then((Ergebnis) => {
  console.log(Ergebnis);
}).catch((Fehler) => {
  konsole.log(Fehler);
})

Nach 1 Sekunde wird die Aufgabe zur Lösung weitergeleitet und die nachfolgende Verarbeitung erfolgt in „then“ oder „catch“.

Beachten

Ausstehender Status => abgelehnter Status:

Kopie

1. Anruf ablehnen

2. Fehler bei der Codeausführung

3. Fehler manuell auslösen

Nachfolgende Verarbeitungsfunktionen müssen asynchron erfolgen und werden in die Mikrowarteschlange gestellt.

Nachdem der JS-Ausführungsstapel gelöscht wurde, werden zuerst die Aufgaben in der Mikrowarteschlange ausgeführt. Nachdem die Aufgaben in der Mikrowarteschlange gelöscht wurden, werden die Aufgaben in der Makrowarteschlange ausgeführt.

  • Zu den Warteschlangen für Makroaufgaben gehören: setTimeout, setInterval, setImmediately, I/O, UI-Render
  • Zu den Microtask-Warteschlangen gehören: promise, process.nexttick, Object.observe (nicht mehr verwendet), Mutation.observe

Async await ist die syntaktische Vereinfachung von Promise, die in es7 hinzugefügt wurde. Sie können auch mehr darüber erfahren. Dieser Artikel gibt nur einen Überblick über Promise. Es gibt noch viele weitere Details, die man beherrschen muss.

Oben sind die Details der asynchronen JS ES6-Lösung aufgeführt. Weitere Informationen zur asynchronen ES6-Lösung finden Sie in den anderen verwandten Artikeln auf 123WORDPRESS.COM!

Das könnte Sie auch interessieren:
  • JS beherrscht schnell die Verwendung von ES6-Klassen
  • Detaillierte Erläuterung der Destrukturierungszuweisung von JS ES6-Variablen
  • Mehrere magische Verwendungen des JS ES6 Spread-Operators
  • Lassen Sie uns über Destrukturierung in JS ES6 sprechen
  • Implementierung der Javascript-Destrukturierung in ES6
  • Verwendung und Unterschied zwischen let und const in der ES6-Spezifikation in JavaScript
  • 24 ES6-Methoden zur Lösung praktischer JS-Entwicklungsprobleme (Zusammenfassung)
  • Detaillierte Erläuterung des Implementierungsprinzips der JavaScript ES6-Klasse
  • Spezifische Verwendung von ES6-Proxy in JavaScript
  • Detaillierte Erläuterung der JS ES6-Codierungsstandards

<<:  Detaillierte Erklärung von 7 SSH-Befehlsverwendungen in Linux, die Sie nicht kennen

>>:  InnoDB-Typ MySql stellt Tabellenstruktur und Daten wieder her

Artikel empfehlen

Warum MySQL Repeatable Read als Standardisolationsebene wählt

Inhaltsverzeichnis Oracle-Isolationsebenen MySQL-...

Zusammenfassung der Situationen, in denen MySQL-Indizes nicht verwendet werden

Indextypen in MySQL Im Allgemeinen können sie in ...

So verwenden Sie den Linux-Befehl nl

1. Befehlseinführung nl (Anzahl der Zeilen) fügt ...

Detaillierte Analyse des Blockierungsproblems von js und css

Inhaltsverzeichnis DOMContentLoaded und laden Was...

Docker mountet lokale Verzeichnisse und Datenvolumen-Container-Operationen

1. Docker mountet das lokale Verzeichnis Docker k...

React realisiert sekundären Verknüpfungseffekt (Treppeneffekt)

In diesem Artikel wird der spezifische Code von R...

Detaillierte Zusammenfassung von MySQL und verbindungsbezogenen Timeouts

MySQL und verbindungsbezogene Timeouts Vorwort: H...

Detaillierte Erklärung einer Methode zum Umbenennen von Prozeduren in MySQL

Kürzlich habe ich die Funktion zum Umbenennen ges...

Detailliertes Tutorial zur Installation von Protobuf 3 unter Ubuntu

Wann ist die Installation durchzuführen? Wenn Sie...

Problem mit der Kompilierung des Nginx RTMP-Moduls in der Arm-Version

Inhaltsverzeichnis 1. Vorbereitung: 2. Quellcode-...

Detailliertes Tutorial zum Konfigurieren der lokalen Yum-Quelle in CentOS8

Die Centos8-Distribution wird über die BaseOS- un...