Heim > Web-Frontend > js-Tutorial > Asynchron und warten in JavaScript

Asynchron und warten in JavaScript

Linda Hamilton
Freigeben: 2025-01-10 14:30:42
Original
513 Leute haben es durchsucht

Async and Await In JavaScript

Einführung in asynchrones JavaScript

JavaScript ist Single-Threaded, was bedeutet, dass es jeweils nur eine Aufgabe ausführen kann. Um mehrere Aufgaben zu bewältigen, insbesondere E/A-Vorgänge wie API-Anfragen oder das Lesen von Dateien, verwendet JavaScript asynchrone Programmierung. Dadurch können andere Aufgaben weiter ausgeführt werden, während auf den Abschluss lang andauernder Vorgänge gewartet wird.

Rückruffunktionen

Anfangs wurden asynchrone Aufgaben in JavaScript mithilfe von Callback-Funktionen abgewickelt. Ein Callback ist eine Funktion, die als Argument an eine andere Funktion übergeben wird und dann nach Abschluss der Operation ausgeführt wird.

Beispiel:

function fetchData(callback) {
    setTimeout(() => {
        callback('Data fetched');
    }, 2000);
}

fetchData((message) => {
    console.log(message);
});
Nach dem Login kopieren

Versprechen

Versprechen wurden eingeführt, um asynchrone Vorgänge effektiver abzuwickeln. Ein Versprechen stellt einen Wert dar, der jetzt, in der Zukunft oder nie verfügbar sein kann.

Beispiel:

let promise = new [Promise]((resolve, reject) => {
    setTimeout(() => {
        resolve('Data fetched');
    }, 2000);
});

promise.then((message) => {
    console.log(message);
}).catch((error) => {
    console.error(error);
});
Nach dem Login kopieren

Asynchron/Warten

Async/Await ist ein syntaktischer Zucker, der auf Promises aufbaut und dafür sorgt, dass asynchroner Code wie synchroner Code aussieht und sich wie synchroner Code verhält. Dadurch ist der Code leichter zu lesen und zu verstehen.

Grundlegende Verwendung

  1. Asynchrone Funktion: Eine mit dem Schlüsselwort async deklarierte Funktion gibt ein Versprechen zurück.
  2. Await-Schlüsselwort: Das Wait-Schlüsselwort kann nur innerhalb einer asynchronen Funktion verwendet werden. Dadurch wartet JavaScript, bis das Versprechen aufgelöst oder abgelehnt wird.

Beispiel:

async function fetchData() {
    let promise = new Promise((resolve, reject) => {
        setTimeout(() => resolve('Data fetched'), 2000);
    });

    let result = await promise; // Wait until the promise resolves
    console.log(result);
}

fetchData();
Nach dem Login kopieren

Fehlerbehandlung

Mit async/await wird die Fehlerbehandlung mithilfe von try...catch-Blöcken unkompliziert.

Beispiel:

async function fetchData() {
    try {
        let promise = new Promise((resolve, reject) => {
            setTimeout(() => reject('Error fetching data'), 2000);
        });

        let result = await promise;
        console.log(result);
    } catch (error) {
        console.error(error);
    }
}

fetchData();
Nach dem Login kopieren

Parallele Ausführung

Um mehrere asynchrone Vorgänge parallel auszuführen, kann Promise.all mit async/await verwendet werden.

Beispiel:

async function fetchAllData() {
    let promise1 = new Promise((resolve) => setTimeout(() => resolve('Data 1'), 2000));
    let promise2 = new Promise((resolve) => setTimeout(() => resolve('Data 2'), 1000));

    let results = await Promise.all([promise1, promise2]);
    console.log(results); // ['Data 1', 'Data 2']
}

fetchAllData();
Nach dem Login kopieren

Fortgeschrittene Konzepte

Sequentielle Ausführung

Wenn Aufgaben nacheinander ausgeführt werden müssen, verwenden Sie „await“ nacheinander.

Beispiel:

async function fetchSequentialData() {
    let data1 = await new Promise((resolve) => setTimeout(() => resolve('Data 1'), 2000));
    console.log(data1);

    let data2 = await new Promise((resolve) => setTimeout(() => resolve('Data 2'), 1000));
    console.log(data2);
}

fetchSequentialData();
Nach dem Login kopieren

Kombination von Async/Await mit traditionellen Versprechen

Sie können Async/Await mit traditionellen Promise-Methoden wie then und Catch kombinieren.

Beispiel:

async function fetchData() {
    let data = await fetch('https://api.example.com/data');
    return data.json();
}

fetchData().then((data) => {
    console.log(data);
}).catch((error) => {
    console.error(error);
});
Nach dem Login kopieren

Abschluss

Async/Await vereinfacht die Arbeit mit asynchronen Vorgängen in JavaScript, indem es eine sauberere und besser lesbare Möglichkeit bietet, asynchronen Code zu schreiben. Es ersetzt effektiv Rückrufe und macht die Arbeit mit Promises intuitiver.

Das obige ist der detaillierte Inhalt vonAsynchron und warten in JavaScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
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