最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 浅谈Koa框架

    正文概述 掘金(jad_design)   2021-03-04   1154

    前言

    在前言中,首先想提出这样三个问题:

    1.前端开发者学习Node开发的意义?

    2.Node开发可以帮助我们解决哪些问题?

    3.什么是Koa框架?

    Node开发的意义

    近些年,随着前端领域涉及的范围越来越广,前端开发者关注的事情也越来越多。之前大多数人对于前端的定义是负责页面展示,并不需要去关心数据。但随着业务的发展,更多的前端开发者开始关注接口的定义、前后端的交互以及数据结构的设计与实现。Node相对于传统的C、C++、Python、Java等语言更容易上手,其语法特性也容易被前端开发者所接受,因为Node应该是前端学习的首选。学习Node可以定义更清晰的架构,帮助前端扩展业务范围,也意味着更多的可能性。

    Node开发解决的问题

    现在前后端的定义愈发模糊,在许多公司的中大型项目中,架构已经由传统的前后双层结构发展为前中后三层结构。与此同时前端开发者最为清楚自己需要哪些数据结构,所以将数据结构的定义交给前端开发者是比较好的做法。此外还可以将后端中和客户端更为紧密的部分抽离出来,形成中间件,比如服务端渲染、数据聚合、接口转发等等。

    基础

    Koa框架的定义

    Koa框架是一个基于Node实现的web框架。

    对比于Express框架,丢弃了回调函数,并有效地增强了异常处理。

    丢弃回调函数是因为Koa使用Promise配合Async函数实现异步,解决了Node回调地狱的问题。 Express框架实现错误处理是通过错误处理中间件,这样把错误一层一层抛出来,交由错误处理中间件处理;而到了Koa则是通过全局错误事件监听,这样把错误处理写在最外层即可。

    Koa框架的发展

    Koa框架的发展:

    Express => Koa => Koa2(Koa框架的发展史本质上是Node的web框架的发展史)

    其实质上是中间件实现方式上的变更:

    线性结构=>generator+co库=>Promise+Async

    Express框架

    Express实现的原理是对Node.js的http进行了封装。

    浅谈Koa框架

    缺点:Express基于的是ES5语法,因此要实现异步代码,只有一个方法就是回调。当嵌套层次较多的时候,就会出现我们比较熟悉的回调地狱的问题。

    Koa1.0

    Koa1.0是基于Es6的generator重写的一个web框架。

    浅谈Koa框架

    Koa2.0

    Koa2.0在Koa1.0的基础上,使用了Es6语法进行了重构,使用Promise配合Async实现异步。

    浅谈Koa框架

    Express中间件实现

    Express线性模型中间件是通过堆栈实现的。

    浅谈Koa框架

    源码解析

    浅谈Koa框架

    与中间件有关的部分:

    1. router文件夹处理的是路由的逻辑。

    2. pplication.js挂载了所有的核心方法。

    3. express.js继承application.js并对外暴露接口。

    其中application.js包含了两个比较重要的方法,proto.use和proto.handle两个方法。

    浅谈Koa框架

    proto.use将我们需要挂载的中间件存储到自身的stack属性上。

    浅谈Koa框架浅谈Koa框架

    proto.handle的核心思想是通过对于next方法的递归调用,对stack中的中间件取出执行。

    为什么说Express中间是线性结构?

    浅谈Koa框架

    浅谈Koa框架

    当有异步代码时,将会跳过异步代码(next)执行,需要等待当前队列中的事件全部执行完毕,因此代码的输出是线性的。

    Koa中间件实现原理

    Koa的中间件实现方式上与Express不同,Express选择了线性模型,Koa选择了洋葱圈模型。

    浅谈Koa框架

    洋葱圈模型特点:所有的请求经过一个中间件的时候都会执行两次;非常方便的实现后置处理逻辑。

    源码解析

    Koa与Express相比在中间件实现方式上最大的不同是use方法的不同。

    浅谈Koa框架

    浅谈Koa框架

    浅谈Koa框架

    浅谈Koa框架

    浅谈Koa框架

    在Koa的use函数内,中间件入栈,在compose函数中对中间件数组进行递归调用,返回一个promise链。整个过程的核心就是调用compose函数,将中间件函数数组转化为compose函数const fn = compose(this.middlewaire);然后调用fn,就会依次执行所有的中间件函数;而且上下文ctx也会贯穿所有的中间件函数。

    总结

    一句话概括学习Node开发对于一个前端开发者的意义:短期小收益,中期高收益,长期必然趋势。我们可以有更丰富的手段去进行业务上的改进,也可以对前后端交互有更为深刻的认识。而Koa框架对比Express,无论从结构上还是语法上都更为适合以后前端的发展,所以更为推荐采用Koa框架去进行前端扩展的开发。


    起源地下载网 » 浅谈Koa框架

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元