全国旗舰校区

不同学习城市 同样授课品质

北京

深圳

上海

广州

郑州

大连

武汉

成都

西安

杭州

青岛

重庆

长沙

哈尔滨

南京

太原

沈阳

合肥

贵阳

济南

下一个校区
就在你家门口
+
当前位置:首页  >  技术干货

千锋web前端培训班:koa中间件是如何实现的?

发布时间:2021-08-27 08:35:00
发布人:小千

      在前端开发过程中我们可能会使用到koa中间件,但很多同学却不知道它是如何实现的,下面小千就来给大家介绍一下这个koa中间件(洋葱模型)。

      一、问题分析

      async await是promise的语法糖,await后面跟一个promise,所以上面的代码可以写成:

千锋<a href=web前端培训1" />

      改成这样更好理解一些,所以流程控制的核心在于next的实现。next要求调用队列中下一个middleware,当达到最后一个的时候resolve。这样最后面的promise先resolve,一直到第一个,这样就是洋葱模型的顺序了。

      二、实现

      koa-compose的实现是这样的:

千锋web前端培训2

      我们把一些参数检查的非核心逻辑去掉了,实现代码就上面那些。每次传入的next都是调用下一个middleware,这样是一个递归的过程,结束条件是最后一个middleware的next是用户传入的。

      这里面有一些亮点:

      1.这是一种尾递归的形式,尾递归的特点是最后返回的值是一个递归的函数调用,这样执行完就会在调用栈中销毁,不会占据调用栈.

      2.返回的是一个Promise.resolve包装之后的调用,而不是同步的调用,所以这是一个异步递归,异步递归比同步递归的好处是可以被打断,如果中间有一些优先级更高的微任务,那么可以先执行别的微任务

      3.compose是函数复合,把n个middleware复合成一个,参数依然是context和next,这种复合之后依然是一个middleware,还可以继续进行复合。

      三、总结

      Koa 中间件的实现原理,也就是洋葱模型的实现原理,核心在于next的实现。next需要依次调用下一个middleware,当到最后一个的时候结束,这样后面middleware的promise先resolve,然后直到第一个,这样的流程也就是洋葱模型的流程了。

      实现的时候还有一些细节,一个是递归最好做成尾递归的形式,而是用异步递归而不是同步递归,第三就是形式上用函数复合的形式,这样复合之后的中间件还可以继续复合。

      已上就是koa中间件的实现原理和案例介绍了,相信大家看完之后就能明白了,最后欢迎对web前端开发培训感兴趣的同学来到千锋web前端培训班参加我们的web前端培训课程的学习,为期两周的免费试听,更有全套web前端学习资料领取,赶紧来找在线老师了解一下。

      千锋web前端培训班http://www.mobiletrain.org/page/html5.html

相关文章

数据库可重复读这种隔离级别的意义是什么?

数据库可重复读这种隔离级别的意义是什么?

2023-10-14
为什么数据库 DDL 不支持事务回滚?

为什么数据库 DDL 不支持事务回滚?

2023-10-14
列式数据库与行式数据库主要区别有哪些?

列式数据库与行式数据库主要区别有哪些?

2023-10-14
怎么向VFP数据表中一次加入多条记录?

怎么向VFP数据表中一次加入多条记录?

2023-10-14

最新文章

常见网络安全面试题:Windows常用的命令有哪些?

常见网络安全面试题:Windows常用的命令有哪些?

2023-10-09
常见网络安全面试题:根据设备告警如何展开排查?

常见网络安全面试题:根据设备告警如何展开排查?

2023-10-09
常见网络安全面试题:mysql加固呢?(数据库加固)

常见网络安全面试题:mysql加固呢?(数据库加固)

2023-10-09
常见网络安全面试题:windows和linux加固?(操作系统加固)

常见网络安全面试题:windows和linux加固?(操作系统加固)

2023-10-09
在线咨询 免费试学 教程领取