Home Web Front-end JS Tutorial What are the usages of async&await in Koa2?

What are the usages of async&await in Koa2?

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

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);
Copy after login

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(&#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)
   }
  }
 }
}
Copy after login

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
})
Copy after login

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(&#39;something wrong!&#39;)
  ctx.body = &#39;Hello&#39;
})
Copy after login

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!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Is async for es6 or es7? Is async for es6 or es7? Jan 29, 2023 pm 05:36 PM

async is es7. async and await are new additions to ES7 and are solutions for asynchronous operations; async/await can be said to be syntactic sugar for co modules and generator functions, solving js asynchronous code with clearer semantics. As the name suggests, async means "asynchronous". Async is used to declare that a function is asynchronous; there is a strict rule between async and await. Both cannot be separated from each other, and await can only be written in async functions.

How vue3+async-validator implements form validation How vue3+async-validator implements form validation May 11, 2023 am 09:55 AM

Building a vue3 project Before creating a project, the first thing we need to explain is that the version we use is Nodejs: v17.5.0pnpm: 7.0.0Vue: 3.2.25. First, we Vite creates a vue3 project demo named FormValidate. Enter the command pnpmcreateviteFormValidate on the command line and press Enter, then select vue and continue to press Enter, indicating that we have initially created the FormValidate (form validation) project. According to the command line prompts, we enter the project root directory, and then use the command pnpminstall to install the dependencies required for the project. Of course Using pnpm here is better than n

How to use async/await to handle asynchronous operations in Vue How to use async/await to handle asynchronous operations in Vue Jun 11, 2023 am 09:18 AM

How to use async/await to handle asynchronous operations in Vue With the continuous development of front-end development, we need to handle more complex asynchronous operations in Vue. Although Vue already provides many convenient ways to handle asynchronous operations, in some cases, we may need to use a simpler and more intuitive way to handle these asynchronous operations. At this time, async/await becomes a very good choice. What is async/await? In ES2017, async and

How to use Python async module How to use Python async module May 30, 2023 pm 11:43 PM

Coroutine: Coroutine, also known as micro-thread, is a context switching technology in user mode. In short, it is actually a thread to implement code blocks to switch between executions. Python's support for coroutines is implemented through generators. In the generator, we can not only iterate through the for loop, but also continuously call the next() function to obtain the next value returned by the yield statement. But Python's yield can not only return a value, it can also receive parameters sent by the caller. 1. What is a generator? In Python, this mechanism of looping and calculating at the same time is called a generator: gene

What exactly is going on with coroutines in Python? What exactly is going on with coroutines in Python? Apr 14, 2023 am 08:28 AM

1. The traditional Sync syntax request example is still the same. Before understanding the implementation of Async syntax, let's start with a Sync syntax example. Now suppose there is an HTTP request. This program will obtain the corresponding response content through this request and print it out. , the code is as follows: import socket def request(host: str) -&gt; None: """Simulate the request and print the response body""" url: str = f"http://{host}" sock

Let's talk about how to use async functions in Node Let's talk about how to use async functions in Node Dec 20, 2022 pm 09:16 PM

With the new version of the V8 engine, Node.js supports async function features starting from 7.6. On October 31 this year, Node.js 8 also became a new long-term support version, so you can use async functions in your code with confidence. In this article, I will briefly introduce what async functions are and how they can change the way we write Node.js applications.

How to connect koa2 to mysql in Nodejs How to connect koa2 to mysql in Nodejs Jun 01, 2023 pm 12:40 PM

Convert query results into objects or arrays. In real development, some query results should actually be put into an object JSON_OBJECT: () is in the form of key-value SELECT products.idasid, products.titleastitle, products.priceasprice, products .scoreasscore,JSON_OBJECT('id',brand.id,'name',brand.name,'rank&#

Let's talk about what 'chemical reactions” will occur when using await in JS loops Let's talk about what 'chemical reactions” will occur when using await in JS loops Mar 02, 2023 pm 05:22 PM

This article brings you relevant knowledge about JavaScript loops. It mainly talks about how to use await in js loops and result analysis. Friends who are interested should take a look at it. I hope it will be helpful to everyone.

See all articles