美文网首页
Koa 中间件机制的洋葱圈模型

Koa 中间件机制的洋葱圈模型

作者: 凯俊 | 来源:发表于2019-03-26 23:21 被阅读0次
const Koa = require('koa');
const app = new Koa();

app.use(async (ctx, next) => {
    console.log(1);
    await next();
    console.log(6);
});

app.use(async (ctx, next) => {
    console.log(2);
    await next();
    console.log(5);
});

app.use(async (ctx, next) => {
    console.log(3);
    ctx.body = "hello world";
    console.log(4);
});

app.listen(3000, () => {
    console.log('listenning on 3000');
});

上面的代码执行后会输出123456,就像一个洋葱一样,从外层进去,然后碰到next()就执行下一个中间件,执行完成后再返回回来。先假设我们已经实现了next为下个中间件这段代码,上面的执行逻辑就很清楚了,先输出1,然后进入下一个中间件,去处理2,同理最后后面都处理完成后处理55处理完成后第二个中间件结束,然后第一个中间件再处理6

所以现在就是怎么实现这个代码。通过看Koa的源码我们可以发现它是通过koa-compose这个库实现的,代码很短,如下:

function compose (middleware) {
  return function (context, next) {
    // last called middleware #
    let index = -1
    return dispatch(0)
    function dispatch (i) {
      if (i <= index) return Promise.reject(new Error('next() called multiple times'))
      index = i
      let fn = middleware[i]
      if (i === middleware.length) fn = next
      if (!fn) return Promise.resolve()
      try {
        return Promise.resolve(fn(context, dispatch.bind(null, i + 1)));
      } catch (err) {
        return Promise.reject(err)
      }
    }
  }
}

核心代码就是return Promise.resolve(fn(context, dispatch.bind(null, i + 1)));这里了,每次执行中间件时,会将第二个中间件作为函数的第二个参数传进去。这也就和上面的async (ctx, next) => {}写法对应上了,所以执行next()就可以执行下一个中间件了。

相关文章

  • koa 中间件机制以及异常捕获

    koa 中间件机制以及异常捕获 koa 中间件机制解析 koa 的请求处理是典型的洋葱模型,下面是官方的配图,而这...

  • Koa2源码阅读: 中间件机制

    中间件机制(洋葱模型):它实现中间件级联调用是借助 koa-compose这个库来实现的。源码只有一个函数。 我...

  • Koa 中间件机制的洋葱圈模型

    上面的代码执行后会输出123456,就像一个洋葱一样,从外层进去,然后碰到next()就执行下一个中间件,执行完成...

  • koa

    koa的处理流程 koa的中间件 洋葱模型实现 通过await next();进入下一个中间件 next是comp...

  • koa全攻略

    1.什么是洋葱模型 简单介绍 用一句话来说,koa,express框架的中间件的执行顺序,可以比喻成洋葱模型。 我...

  • jk node笔记(2)

    express 中间件在没有异步的情况下,符合洋葱模型,一旦有了异步,就会打破洋葱模型。koa 中使用异步函数写中...

  • (三)koa-router路由器搭建

    koa2中间件机制-洋葱圈,很好的解决了异步传输的问题,使用async和await就可以轻松解决。现在先完成简单测...

  • Express和 Koa 的区别

    1. Koa 原理 封装请求和响应 通过U型模型/洋葱模型构造中间件 2. 跟Express的区别 2.1 编程模...

  • 【Node】深入浅出 Koa 的洋葱模型

    本文将讲解 koa 的洋葱模型,我们为什么要使用洋葱模型,以及它的原理实现。掌握洋葱模型对于理解 koa 至关重要...

  • koa洋葱模型原理

    首先,关于 洋葱模型 自上而下-》自下而上 回溯机制并不是 koa 自己的特性,而是 async/await 自己...

网友评论

      本文标题:Koa 中间件机制的洋葱圈模型

      本文链接:https://www.haomeiwen.com/subject/zqiovqtx.html