在koa中,一切的流程都是中间件,数据流向遵循洋葱模型,先入后出,是按照类似堆栈的方式组织和执行的,koa-compose是理解koa中间件的关键,在koa中间件中会深入分析。
koa2与koa1的最大区别是koa2实现异步是通过async/awaite,koa1实现异步是通过generator/yield,而express实现异步是通过回调函数的方式。
koa2与express 提供的API大致相同,express是大而全,内置了大多数的中间件,更让人省心,koa2不绑定任何的框架,干净简洁,小而精,更容易实现定制化,扩展性好。
express是没有提供ctx来提供上下流服务,需要更多的手动处理,express本身是不支持洋葱模型的数据流入流出能力的,需要引入其他的插件。
koa的数据流入流出,next()后,会进入下一个中间件并执行,然后从最后一个中间件反向执行。
const Koa = require('koa')
const app = new Koa()
const mid1 = async (ctx, next) => {
ctx.body = '前:' + '1\n'
await next()
ctx.body = ctx.body + '后:' + '1\n'
}
const mid2 = async (ctx, next) => {
ctx.body = ctx.body + '前:'+ '2\n'
await next()
ctx.body = ctx.body + '后:'+ '2\n'
}
const mid3 = async (ctx, next) => {
ctx.body = ctx.body + '前:'+ '3\n'
await next()
ctx.body = ctx.body + '后:'+ '3\n'
}
app.use(mid1)
app.use(mid2)
app.use(mid3)
app.listen(3000)
这种这行方式,看起来很像是递归操作:
function tail (i) {
if (i > 3) return
console.log('前:',i)
tail(i + 1)
console.log('后:',i)
}
tail(1)
递归存在着栈溢出问题,有可能把js引擎卡死,koa采用的是一种尾调用的方式进行了性能优化。