Rumah hujung hadapan web tutorial js Koa2中有关async&await的用法有哪些?

Koa2中有关async&await的用法有哪些?

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

这篇文章主要介绍了理解Koa2中的async&await的用法,现在分享给大家,也给大家做个参考。

Koa是一款非常著名的Node服务端框架,有1.x版本和2.x版本。前者使用了generator来进行异步操作,后者则用了最新的async/await方案

一开始使用这种写法的时候,我遇到一个问题,代码如下:

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);
Salin selepas log masuk

让我们测试一下:curl http://localhost:3000

期望结果:

(3秒后...)task done!

然而现实却是:

(立即)
Not Found

什么鬼?为什么没有按照预期执行?这就需要我们来理解下Koa中中间件是如何串联起来的了。翻一下源码,将middlewares串联起来的代码如下:

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)
   }
  }
 }
}
Salin selepas log masuk

有了以上基础,我们再来看一下之前的问题,为什么response没有等到第二个middleware执行完成就立即返回了呢?

因为第一个middleware并不是一个异步函数啊。

由于每次next方法的执行,实际上都是返回了一个Promise对象,所以如果我们在某个middleware中执行了异步操作,要想等待其完成,就要在执行这个middleware之前添加await

那我们来改写一下之前的代码

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
})
Salin selepas log masuk

好了,没有问题,一切如期望执行:clap:

错误处理

借助了Promise强大的功力,配合async/await语法,我们只需要把try/catch的操作写在最外层的middleware中,就可以捕获到之后所有中间件的异常!

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;
})
Salin selepas log masuk

基于中间件链的完全控制,并且基于 Promise 的事实使得一切都变得容易操作起来。不再是到处的 if (err) return next(err) 而只有 promise

上面是我整理给大家的,希望今后会对大家有帮助。

相关文章:

在D3.js中如何实现动态进度条

vue中实现模态框(通用写法)

在Vue.js 2.0和Cordova开发中如何搭建webApp环境

Atas ialah kandungan terperinci Koa2中有关async&await的用法有哪些?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Adakah async untuk es6 atau es7? Adakah async untuk es6 atau es7? Jan 29, 2023 pm 05:36 PM

async ialah es7. async dan await ialah penambahan baharu kepada ES7 dan merupakan penyelesaian untuk operasi asynchronous/wait boleh dikatakan sebagai gula sintaktik untuk modul bersama dan fungsi penjana, menyelesaikan kod tak segerak dengan semantik yang lebih jelas. Seperti namanya, async bermaksud "tak segerak".

Cara vue3+async-validator melaksanakan pengesahan borang Cara vue3+async-validator melaksanakan pengesahan borang May 11, 2023 am 09:55 AM

Membina projek vue3 Sebelum mencipta projek, perkara pertama yang perlu kami jelaskan ialah versi yang kami gunakan ialah Nodejs: v17.5.0pnpm: 7.0.0Vue: 3.2.25 Pertama, kami Vite mencipta demo projek vue3 bernama FormValidate. Masukkan arahan pnpmcreateviteFormValidate pada baris arahan dan tekan Enter, kemudian pilih vue dan terus tekan Enter, menunjukkan bahawa kami pada mulanya telah mencipta projek FormValidate (pengesahan borang) Menurut arahan baris arahan, kami memasuki direktori akar projek, dan kemudian gunakan arahan pnpminstall untuk memasang kebergantungan yang diperlukan untuk projek Sudah tentu Menggunakan pnpm di sini adalah lebih baik daripada n

Bagaimana untuk menggunakan modul async Python Bagaimana untuk menggunakan modul async Python May 30, 2023 pm 11:43 PM

Coroutine: Coroutine, juga dikenali sebagai micro-thread, ialah teknologi penukaran konteks dalam mod pengguna. Ringkasnya, ia sebenarnya adalah satu utas untuk melaksanakan blok kod untuk bertukar antara pelaksanaan sokongan Python untuk coroutine dilaksanakan melalui penjana. Dalam penjana, kita bukan sahaja boleh melelar melalui gelung for, tetapi juga terus memanggil fungsi next() untuk mendapatkan nilai seterusnya yang dikembalikan oleh pernyataan hasil. Tetapi hasil Python bukan sahaja dapat mengembalikan nilai, ia juga boleh menerima parameter yang dihantar oleh pemanggil. 1. Apakah penjana? Dalam Python, mekanisme gelung dan pengiraan pada masa yang sama dipanggil penjana: gen

Cara menggunakan async/menunggu untuk mengendalikan operasi tak segerak dalam Vue Cara menggunakan async/menunggu untuk mengendalikan operasi tak segerak dalam Vue Jun 11, 2023 am 09:18 AM

Cara menggunakan tak segerak/menunggu untuk mengendalikan operasi tak segerak dalam Vue Dengan pembangunan berterusan pembangunan bahagian hadapan, kami perlu mengendalikan operasi tak segerak yang lebih kompleks dalam Vue. Walaupun Vue sudah menyediakan banyak cara mudah untuk mengendalikan operasi tak segerak, dalam sesetengah kes, kita mungkin perlu menggunakan cara yang lebih mudah dan lebih intuitif untuk mengendalikan operasi tak segerak ini. Pada masa ini, async/menunggu menjadi pilihan yang sangat baik. Apakah async/menunggu? Dalam ES2017, async dan

Apa sebenarnya yang berlaku dengan coroutine dalam Python? Apa sebenarnya yang berlaku dengan coroutine dalam Python? Apr 14, 2023 am 08:28 AM

1. Contoh permintaan sintaks Penyegerakan masih sama Sebelum memahami pelaksanaan sintaks Async, mari kita mulakan dengan contoh sintaks Penyegerakan Sekarang andaikan terdapat permintaan HTTP ini ia keluar , kodnya adalah seperti berikut: import socket def request(host: str) -&gt; }" stokin

Mari kita bincangkan tentang cara menggunakan fungsi async dalam Node Mari kita bincangkan tentang cara menggunakan fungsi async dalam Node Dec 20, 2022 pm 09:16 PM

Dengan versi baharu enjin V8, Node.js menyokong ciri fungsi async bermula dari 7.6. Pada 31 Oktober tahun ini, Node.js 8 juga menjadi versi sokongan jangka panjang baharu, jadi anda boleh menggunakan fungsi async dalam kod anda dengan yakin. Dalam artikel ini, saya akan memperkenalkan secara ringkas apakah fungsi async dan cara ia boleh mengubah cara kami menulis aplikasi Node.js.

Mari kita bincangkan tentang 'tindak balas kimia' yang akan berlaku apabila menggunakan await dalam gelung JS Mari kita bincangkan tentang 'tindak balas kimia' yang akan berlaku apabila menggunakan await dalam gelung JS Mar 02, 2023 pm 05:22 PM

Artikel ini membawakan anda pengetahuan yang berkaitan tentang gelung JavaScript terutamanya tentang cara menggunakan gelung js dan analisis hasil. Saya harap ia dapat membantu semua orang.

Bagaimana untuk menyambung koa2 ke mysql dalam Nodejs Bagaimana untuk menyambung koa2 ke mysql dalam Nodejs Jun 01, 2023 pm 12:40 PM

Tukar hasil pertanyaan kepada objek atau tatasusunan Dalam pembangunan sebenar, beberapa hasil pertanyaan sebenarnya harus dimasukkan ke dalam objek JSON_OBJECT: () adalah dalam bentuk nilai kunci SELECT products.idasid, products.titleastitle, products.priceasprice, products .scoreasscore. ,JSON_OBJECT('id',brand.id,'name',brand.name,'rank'

See all articles