Heim Web-Frontend js-Tutorial Was sind die Verwendungszwecke von async&await in Koa2?

Was sind die Verwendungszwecke von async&await in Koa2?

Jun 07, 2018 pm 03:50 PM
async await koa2

In diesem Artikel wird hauptsächlich die Verwendung von async&await zum Verständnis von Koa2 vorgestellt. Jetzt teile ich es mit Ihnen und gebe Ihnen eine Referenz.

Koa ist ein sehr bekanntes serverseitiges Node-Framework mit den Versionen 1.x und 2.x. Ersteres verwendet einen Generator, um asynchrone Vorgänge auszuführen, und letzteres verwendet die neueste Async/Await-Lösung.

Als ich diese Schreibmethode zum ersten Mal verwendete, stieß ich auf ein Problem. Der Code lautet wie folgt:

const Koa = require('koa');
const app = new Koa();

const doSomething = time => {
  return new Promise(resolve => {
    setTimeout(() => {
      resolve('task done!')
    }, time)
  })
}

// 用来打印请求信息
app.use((ctx, next) => {
  console.log(`${ctx.method}:::${ctx.url}`)
  next()
})

app.use(async ctx => {
  const result = await doSomething(3000)
  console.log(result);
  ctx.body = result
})

app.listen(3000);
Nach dem Login kopieren

Testen wir es: curl http://localhost:3000

Erwartetes Ergebnis:

(Nach 3 Sekunden...)Aufgabe erledigt!

Allerdings ist die Die Realität ist:

(sofort)
Nicht gefunden

Was zum Teufel? Warum funktioniert es nicht wie erwartet? Dazu müssen wir verstehen, wie die Middleware in Koa in Reihe geschaltet ist. Wenn wir uns den Quellcode ansehen, sieht der Code für die Verkettung von Middleware wie folgt aus:

function compose (middleware) {
 return function (context, next) {
  // 这个index用来计数,防止next被多次调用
  let index = -1
  // 执行入口
  return dispatch(0)
  
  function dispatch (i) {
   // 如果next被多次调用,报异常
   if (i <= index) return Promise.reject(new Error(&#39;next() called multiple times&#39;))
   index = i
   // 取出第一个middleware
   let fn = middleware[i]
   // 将最初传入的next作为最后一个函数执行
   if (i === middleware.length) fn = next
   if (!fn) return Promise.resolve()
   try {
    /**
    这里就是关键了,Promise.resolve是什么意思呢?
     Promise.resolve方法有下面三种形式:
     
     Promise.resolve(value);
     Promise.resolve(promise);
     Promise.resolve(theanable);
     
    这三种形式都会产生一个新的Promise。其中:

    第一种形式提供了自定义Promise的值的能力,它与Promise.reject(reason)对应。两者的不同,在于得到的Promise的状态不同。

    第二种形式,提供了创建一个Promise的副本的能力。

    第三种形式,是将一个类似Promise的对象转换成一个真正的Promise对象。它的一个重要作用是将一个其他实现的Promise对象封装成一个当前实现的Promise对象。例如你正在用bluebird,但是现在有一个Q的Promise,那么你可以通过此方法把Q的Promise变成一个bluebird的Promise。第二种形式可以归在第三种里面
    
    **/
    return Promise.resolve(fn(context, function next () {
     // 执行下一个middleware,返回结果也是一个Promise
     return dispatch(i + 1)
    }))
   } catch (err) {
    return Promise.reject(err)
   }
  }
 }
}
Nach dem Login kopieren

Schauen wir uns auf der oben genannten Grundlage die vorherige Frage an: Warum kommt die Antwort sofort zurück, ohne auf die zweite Middleware zu warten? hingerichtet?

Weil die erste Middleware keine asynchrone Funktion ist.

Da jede Ausführung der nächsten Methode tatsächlich ein Promise-Objekt zurückgibt, müssen wir, wenn wir eine asynchrone Operation in einer Middleware ausführen möchten, dies tun, bevor wir die Middleware ausführen

Dann schreiben wir den vorherigen Code neu

app.use(async (ctx, next) => {
  console.log(`${ctx.method}:::${ctx.url}`)
  await next()
})

app.use(async ctx => {
  const result = await doSomething(3000)
  console.log(result);
  ctx.body = result
})
Nach dem Login kopieren

Okay, kein Problem, alles wird wie erwartet ausgeführt: clap:

Fehlerbehandlung

Mit der leistungsstarken Leistungsfähigkeit von Promise und der Async/Await-Syntax müssen wir nur die Try/Catch-Operation in die äußerste Middleware schreiben und können alle nachfolgenden Middleware-Ausnahmen erfassen!

app.use(async (ctx, next) => {
  try{
    await next()
  }catch(err){
    console.log(err)
  }
})

app.use(async (ctx)=>{
  throw new Error(&#39;something wrong!&#39;)
  ctx.body = &#39;Hello&#39;
})
Nach dem Login kopieren

Volle Kontrolle basierend auf der Middleware-Kette und die Tatsache, dass sie auf Promise basiert, macht alles einfach zu bedienen. Es gibt nicht mehr „if“ (ähm) „return next“ (ähm) überall, sondern nur „versprechen“ Das Obige ist das, was ich für alle zusammengestellt habe. Ich hoffe, dass es in Zukunft für alle hilfreich sein wird.

Verwandte Artikel:

So implementieren Sie einen dynamischen Fortschrittsbalken in D3.js

Implementieren einer modalen Box in Vue (allgemeine Schreibmethode)

So erstellen Sie eine WebApp-Umgebung in Vue.js 2.0 und Cordova-Entwicklung

Das obige ist der detaillierte Inhalt vonWas sind die Verwendungszwecke von async&await in Koa2?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ist Async für es6 oder es7? Ist Async für es6 oder es7? Jan 29, 2023 pm 05:36 PM

async ist es7. Async und Wait sind neue Ergänzungen zu ES7 und Lösungen für asynchrone Vorgänge. Man kann sagen, dass Async/Await syntaktischer Zucker für Co-Module und Generatorfunktionen ist und js asynchronen Code mit klarerer Semantik löst. Wie der Name schon sagt, bedeutet Async „asynchron“. Async wird verwendet, um zu deklarieren, dass eine Funktion asynchron ist. Es gibt eine strikte Regel zwischen Async und Wait.

Wie vue3+async-validator die Formularüberprüfung implementiert Wie vue3+async-validator die Formularüberprüfung implementiert May 11, 2023 am 09:55 AM

Erstellen eines Vue3-Projekts Bevor wir ein Projekt erstellen, müssen wir zunächst erklären, dass die von uns verwendete Version Nodejs: v17.5.0pnpm: 7.0.0Vue: 3.2.25 ist. Zuerst erstellt Vite eine Vue3-Projektdemo mit dem Namen FormValidate. Geben Sie den Befehl pnpmcreateviteFormValidate in die Befehlszeile ein und drücken Sie die Eingabetaste. Wählen Sie dann vue aus und drücken Sie weiterhin die Eingabetaste. Dies zeigt an, dass wir zunächst das Projekt FormValidate (Formularvalidierung) erstellt haben. Gemäß den Eingabeaufforderungen in der Befehlszeile geben wir das Stammverzeichnis des Projekts ein Verwenden Sie dann den Befehl pnpminstall, um die für das Projekt erforderlichen Abhängigkeiten zu installieren. Natürlich ist die Verwendung von pnpm hier besser als n

So verwenden Sie async/await, um asynchrone Vorgänge in Vue abzuwickeln So verwenden Sie async/await, um asynchrone Vorgänge in Vue abzuwickeln Jun 11, 2023 am 09:18 AM

So verwenden Sie async/await, um asynchrone Vorgänge in Vue abzuwickeln. Mit der kontinuierlichen Weiterentwicklung der Front-End-Entwicklung müssen wir komplexere asynchrone Vorgänge in Vue verarbeiten. Obwohl Vue bereits viele praktische Möglichkeiten zur Handhabung asynchroner Vorgänge bietet, müssen wir in einigen Fällen möglicherweise eine einfachere und intuitivere Möglichkeit zur Handhabung dieser asynchronen Vorgänge verwenden. Zu diesem Zeitpunkt ist async/await eine sehr gute Wahl. Was ist async/await? In ES2017 sind asynchrone und

So verwenden Sie das Python-Async-Modul So verwenden Sie das Python-Async-Modul May 30, 2023 pm 11:43 PM

Coroutine: Coroutine, auch Micro-Thread genannt, ist eine Kontextwechseltechnologie im Benutzermodus. Kurz gesagt, es handelt sich tatsächlich um einen Thread zum Implementieren von Codeblöcken zum Umschalten zwischen Ausführungen. Die Unterstützung von Python für Coroutinen wird über Generatoren implementiert. Im Generator können wir nicht nur die for-Schleife durchlaufen, sondern auch kontinuierlich die Funktion next() aufrufen, um den nächsten von der yield-Anweisung zurückgegebenen Wert zu erhalten. Aber Pythons yield kann nicht nur einen Wert zurückgeben, sondern auch vom Aufrufer gesendete Parameter empfangen. 1. Was ist ein Generator? In Python wird dieser Mechanismus zum gleichzeitigen Schleifen und Berechnen als Generator bezeichnet: Gen

Was genau passiert mit Coroutinen in Python? Was genau passiert mit Coroutinen in Python? Apr 14, 2023 am 08:28 AM

1. Das herkömmliche Beispiel für die Sync-Syntax ist immer noch dasselbe. Bevor wir die Implementierung der Async-Syntax verstehen, beginnen wir mit einem Beispiel für die Sync-Syntax. Dieses Programm erhält den entsprechenden Antwortinhalt über diese Anfrage it out. Der Code lautet wie folgt: import socket def request(host: str) -&gt; }" Socke

Lassen Sie uns darüber sprechen, wie Sie asynchrone Funktionen in Node verwenden Lassen Sie uns darüber sprechen, wie Sie asynchrone Funktionen in Node verwenden Dec 20, 2022 pm 09:16 PM

Mit der neuen Version der V8-Engine unterstützt Node.js asynchrone Funktionsfunktionen ab 7.6. Am 31. Oktober dieses Jahres wurde auch Node.js 8 zu einer neuen Langzeit-Support-Version, sodass Sie asynchrone Funktionen bedenkenlos in Ihrem Code verwenden können. In diesem Artikel werde ich kurz vorstellen, was asynchrone Funktionen sind und wie sie die Art und Weise verändern können, wie wir Node.js-Anwendungen schreiben.

Lassen Sie uns darüber sprechen, welche „chemischen Reaktionen' ablaufen, wenn „await' in JS-Schleifen verwendet wird Lassen Sie uns darüber sprechen, welche „chemischen Reaktionen' ablaufen, wenn „await' in JS-Schleifen verwendet wird Mar 02, 2023 pm 05:22 PM

Dieser Artikel vermittelt Ihnen relevantes Wissen über JavaScript-Schleifen. Er befasst sich hauptsächlich mit der Verwendung von „await“ in js-Schleifen und der Ergebnisanalyse. Ich hoffe, dass er für alle hilfreich ist.

So verbinden Sie koa2 mit MySQL in Nodejs So verbinden Sie koa2 mit MySQL in Nodejs Jun 01, 2023 pm 12:40 PM

Konvertieren Sie Abfrageergebnisse in Objekte oder Arrays. In der realen Entwicklung sollten einige Abfrageergebnisse tatsächlich in ein Objekt eingefügt werden. JSON_OBJECT: () hat die Form des Schlüsselwerts SELECT products.idasid, products.titleastitle, products.priceasprice, products.scoreasscore ,JSON_OBJECT('id',brand.id,'name',brand.name,'rank&#

See all articles