Heim >Web-Frontend >js-Tutorial >Wie geben asynchrone Funktionen mithilfe von Async-Await Werte zurück?

Wie geben asynchrone Funktionen mithilfe von Async-Await Werte zurück?

Barbara Streisand
Barbara StreisandOriginal
2024-11-11 13:43:02918Durchsuche

How do Async Functions Return Values Using Async-Await?

Wie asynchrone Funktionen mithilfe von Async-Await Werte zurückgeben

Im Gegensatz zu regulären Funktionen nutzen asynchrone Funktionen die asynchrone Verarbeitung, sodass sie die Ausführung anhalten und fortsetzen können. Dies wirft jedoch eine Frage auf: Wie kann man die zurückgegebenen Werte abrufen?

Die ursprüngliche Abfrage

Zunächst besteht ein üblicher Ansatz darin, Folgendes zu versuchen:

async function getData() {
    const data = await axios.get('https://jsonplaceholder.typicode.com/posts');
    return data;
}
console.log(getData());

Allerdings Dieser Ansatz führt zu einem Promise { }-Ausgabe, da asynchrone Funktionen eine besondere Behandlung erfordern.

Die Magie von Async-Await in Async IIFE

Die Lösung besteht darin, Ihr console.log in einen asynchronen, sofort aufgerufenen Funktionsausdruck (async IIFE) einzubinden ). Es sieht so aus:

async function getData() {
  return await axios.get('https://jsonplaceholder.typicode.com/posts');
}

(async () => {
  console.log(await getData())
})()

Async-Await mit Versprechen

Da Axios ein Versprechen zurückgibt, können Sie die getData-Funktion vereinfachen, indem Sie async/await weglassen:

function getData() {
  return axios.get('https://jsonplaceholder.typicode.com/posts');
}

Und dann wickeln Sie Ihr console.log wie zuvor in das asynchrone IIFE ein:

(async () => {
   console.log(await getData())
})()

Fazit

Durch die Verwendung von async-await in asynchronen IIFEs können Sie die Werte effektiv abrufen und protokollieren von asynchronen Funktionen zurückgegeben, wodurch das Potenzial der asynchronen Programmierung freigesetzt wird.

Das obige ist der detaillierte Inhalt vonWie geben asynchrone Funktionen mithilfe von Async-Await Werte zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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