文章不易,请关注公众号 毛毛虫的小小蜡笔,多多反对,谢谢

先看个Demo

app.use(async (ctx, next) => {  console.log(1)  await next()  console.log(2)  ctx.body = 'Hello Koa';});app.use(async (ctx, next) => {  console.log(3)  await next()  console.log(4)});app.use(async (ctx, next) => {  console.log(5)});

输入后果是:
1
3
5
4
2

这就是所谓的洋葱模型。
第一个中间件在最外层,而后第二个在第二层,第三个则是最外面一层。
所以先执行1,而后到第二层的3,再到最外面的5,执行完后再到第二层的4,最初返回到第一层的2。

看源码

app.use最次要的是把中间件存起来:this.middleware.push(fn)。

详情 请查看:毛毛虫的小小蜡笔