This article mainly introduces the understanding of the usage of async&await in Koa2. Now I share it with you and give you a reference.
Koa is a very famous Node server-side framework, with versions 1.x and 2.x. The former uses a generator to perform asynchronous operations, and the latter uses the latest async/await solution
When I first started using this writing method, I encountered a problem, the code is as follows:
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);
Let us test it: curl http://localhost:3000
Expected result:
(After 3 seconds...)task done!
However, the reality is :
(immediately)
Not Found
What the hell? Why isn't it performing as expected? This requires us to understand how middleware in Koa is connected in series. Looking through the source code, the code for concatenating middlewares is as follows:
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('next() called multiple times')) 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) } } } }
With the above foundation, let’s take a look at the previous question. Why does the response return immediately without waiting for the second middleware to be executed?
Because the first middleware is not an asynchronous function.
Since each execution of the next method actually returns a Promise object, so if we perform an asynchronous operation in a middleware, if we want to wait for it to complete, we must do so before executing the middleware. Add await
Then let’s rewrite the previous code
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 })
Okay, there is no problem, everything is executed as expected:clap:
Error handling
With the help of the powerful power of Promise and the async/await syntax, we only need to write the try/catch operation in the outermost middleware to capture all subsequent middleware exceptions!
app.use(async (ctx, next) => { try{ await next() }catch(err){ console.log(err) } }) app.use(async (ctx)=>{ throw new Error('something wrong!') ctx.body = 'Hello' })
Full control based on the middleware chain, and the fact that it is based on Promise makes everything easy to operate. There is no longer if (err) return next(err) everywhere, but only promise
The above is what I compiled for everyone. I hope it will be helpful to everyone in the future.
Related articles:
How to implement dynamic progress bar in D3.js
Implement modal box in vue (general writing method)
How to build a webApp environment in Vue.js 2.0 and Cordova development
The above is the detailed content of What are the usages of async&await in Koa2?. For more information, please follow other related articles on the PHP Chinese website!

async是es7的。async和await是ES7中新增内容,是对于异步操作的解决方案;async/await可以说是co模块和生成器函数的语法糖,用更加清晰的语义解决js异步代码。async顾名思义是“异步”的意思,async用于声明一个函数是异步的;async和await有一个严格规定,两者都离不开对方,且await只能写在async函数中。

搭建vue3的项目创建项目前这里我们首先要说明的是,我们使用的版本情况Nodejs:v17.5.0pnpm:7.0.0Vue:3.2.25首先我们Vite创建一个vue3的项目demo,名字就叫FormValidate,我们在命令行输入命令pnpmcreateviteFormValidate回车然后选择vue继续回车,说明我们已经初步创建了FormValidate(表单验证)项目根据命令行的提示,我们进入项目根目录,然后使用命令pnpminstall安装项目需要的依赖,当然这里使用pnpm是比n

协程:协程(Coroutine),也可以被称为微线程,是一种用户态内的上下文切换技术。简而言之,其实就是通过一个线程实现代码块相互切换执行Python对协程的支持是通过generator实现的。在generator中,我们不但可以通过for循环来迭代,还可以不断调用next()函数获取由yield语句返回的下一个值。但是Python的yield不但可以返回一个值,它还可以接收调用者发出的参数。一、什么是generator(生成器)在Python中,这种一边循环一边计算的机制,称为生成器:gene

一.传统的Sync语法请求例子还是一样, 在了解Async语法的实现之前, 先从一个Sync的语法例子开始, 现在假设有一个HTTP请求, 这个程序会通过这个请求获取对应的响应内容, 并打印出来, 代码如下:import socket def request(host: str) -> None: """模拟请求并打印响应体""" url: str = f"http://{host}" sock

在Vue中如何使用async/await处理异步操作随着前端开发的不断发展,我们需要在Vue中处理更加复杂的异步操作。虽然Vue已经提供了很多便捷的方式来处理异步操作,但是在某些情况下,我们可能需要使用更加简单、直观的方式来处理这些异步操作。这时候,async/await就成为了一个非常不错的选择。什么是async/await?在ES2017中,async和

本篇文章给大家带来了关于JavaScript循环的相关知识,其中主要给大家聊聊在js循环中怎么使用使用await以及结果分析,感兴趣的朋友一起来看一下吧,希望对大家有帮助。

将查询结果转为对象或者数组在真实开发中,实际上某些查询结果应该放入到一个对象中JSON_OBJECT:()中是key-value的形式SELECTproducts.idasid,products.titleastitle,products.priceasprice,products.scoreasscore,JSON_OBJECT('id',brand.id,'name',brand.name,'rank&#

借助于新版 V8 引擎,Node.js 从 7.6 开始支持 async 函数特性。今年 10 月 31 日,Node.js 8 也开始成为新的长期支持版本,因此你完全可以放心大胆地在你的代码中使用 async 函数了。在这边文章里,我会简要地介绍一下什么是 async 函数,以及它会如何改变我们编写 Node.js 应用的方式。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

Atom editor mac version download
The most popular open source editor

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.
