位置: 编程技术 - 正文

nodejs模块学习之connect解析(nodejs基础教程)

编辑:rootadmin

推荐整理分享nodejs模块学习之connect解析(nodejs基础教程),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:nodejs常用模块,nodejs model,nodejs node_modules,nodejs实战教程,nodejs.,nodejs.,nodejs 模块,nodejs实战教程,内容如对您有帮助,希望把文章链接给更多的朋友!

nodejs 发展很快,从 npm 上面的包托管数量就可以看出来。不过从另一方面来看,也是反映了 nodejs 的基础不稳固,需要开发者创造大量的轮子来解决现实的问题。

知其然,并知其所以然这是程序员的天性。所以把常用的模块拿出来看看,看看高手怎么写的,学习其想法,让自己的技术能更近一步。

引言

express 是 nodejs 中最流行的 web 框架。express 中对 http 中的 request 和 response 的处理,还有以中间件为核心的处理流程,非常灵活,足以应对任何业务的需求。

而 connect 曾经是 express 3.x 之前的核心,而 express 4.x 已经把 connect 移除,在 express 中自己实现了 connect 的接口。可以说 connect 造就了 express 的灵活性。

因此,我很好奇,connect 是怎么写的。

争取把每一行代码都弄懂。

connect 解析

我们要先从 connect 的官方例子开始

从示例中可以看到一个典型的 connect 的使用:

先倒着看,从调用的地方更能看出来,模块怎么使用的。我们就先从 http.createServer(app) 来看看。

从 nodejs doc 的官方文档中可以知, createServer 函数的参数是一个回调函数,这个回调函数是用来响应 request 事件的。从这里看出,示例代码中 app 中函数签就是 (req, res) ,也就是说 app 的接口为 function (req, res) 。

但是从示例代码中,我们也可以看出 app 还有一个 use 方法。是不是觉得很奇怪,js 中函数实例上,还以带方法,这在 js 中就叫 函数对象,不仅能调用,还可以带实例变量。给个例子可以看得更清楚:

可以看出:函数中的实例函数中的 this 就是指当前的实例,不会因为你使用 apply 进行环境改变。

其他就跟对象没有什么区别。

再次回到示例代码,因该可以看懂了, connect 方法返回了一个函数,这个函数能直接调用,有 use 方法,用来响应 http 的 request 事件。

nodejs模块学习之connect解析(nodejs基础教程)

到此为此,示例代码就讲完了。 我们开始进入到 connect 模块的内部。

connect 只有一个导出方法。就是如下:

从代码中可以看出,createServer 函数把 app 函数返回了,app 函数有三个参数,多了一个 next (这个后面讲),app函数把 proto 的方法合并了。还有 EventEmitter 的方法也合并了,还增加了 route 和 stack 的属性。

从前面代码来看,响应 request 的事件的函数,是 app.handle 方法。这个方法如下:

代码中有相应的注释,可以看出,next 方法就是一个递归调用,不断的对比 route 是否匹配,如果匹配则调用 handle, 如果不匹配,则调用下一个 handle.

call 函数的代码如下:

可以看出一个重点:对错误处理,connect 的要求 是函数必须是 四个参数,而 express 也是如此。如果有错误, 中间件没有一个参数的个数是 4, 就会错误一直传下去,直到后面的 defer(done, err); 进行处理。

还有 app.use 添加中间件:

从代码中,可以看出,use 方法添加中间件到 this.stack 中,其中 fn 中间件的形式有两种: function (req, res, next) 和 handle.handle(req, res, next) 这两种都可以。还有对 fn 情况进行特殊处理。

总的处理流程就是这样,用 use 方法添加中间件,用 next 编历中间件,用 finalHandle 进行最后的处理工作。

在代码中还有一个函数非常奇怪:

defer 函数中的 fn.bind.apply(fn, arguments) ,这个方法主要解决了,一个问题,不定参的情况下,第一个参数函数,怎样拿到的问题,为什么这样说呢?如果中我们要达到以上的效果,需要多多少行代码?

这还是 connect 兼容以前的 es5 之类的方法。如果在 es6 下面,方法可以再次简化

总结

connect 做为 http 中间件模块,很好地解决对 http 请求的插件化处理的需求,把中间件组织成请求上的一个处理器,挨个调用中间件对 http 请求进行处理。

其中 connect 的递归调用,和对 js 的函数对象的使用,让值得学习,如果让我来写,就第一个调个的地方,就想不到使用 函数对象 来进行处理。

而且 next 的设计如此精妙,整个框架的使用和概念上,对程序员基本上没有认知负担,这才是最重要的地方。这也是为什么 express 框架最受欢迎。koa 相比之下,多几个概念,还使用了不常用的 yield 方法。

connect 的设计理念可以用在,类似 http 请求模式上, 如 rpc, tcp 处理等。

我把 connect 的设计方法叫做 中间件模式,对处理 流式模式,会有较好的效果。

标签: nodejs基础教程

本文链接地址:https://www.jiuchutong.com/biancheng/382136.html 转载请保留说明!

上一篇:详解HTTPS 的原理和 NodeJS 的实现

下一篇:nodeJS(express4.x)+vue(vue-cli)构建前后端分离实例(带跨域)

  • 委托加工业务的会计处理
  • 进口环节缴纳关税计入
  • 支付短期借款利息的会计科目
  • 金蝶标准版如何结转到下月
  • 新成立公司交税
  • 对外支付代扣代缴企业所得税
  • 什么样的运输发动机最好
  • 非行政性罚款可以撤销吗
  • 可抵扣农产品进项税额吗
  • 建筑企业劳保计入哪个科目?
  • 增值税专票开具要求
  • 契税的发票开错了还可以作废吗?
  • 股票发行的会计分录
  • 电子承兑必须对账吗
  • 个税手续费返还会计分录
  • 公司员工出差补贴与差旅费报销制度
  • 工程结算收入要交税吗
  • 建筑公司工程款支付审批流程
  • 退关税怎么入账
  • 累计折旧差错调整减少
  • 房地产商铺增值税税率是多少
  • 制作广告费用
  • 分配车间管理人员薪酬会计分录
  • 收到苗木发票怎么做账
  • 电脑管家系统异常要修复吗
  • 异地项目不预缴税款可以开票吗
  • macos itunes
  • 鸿蒙系统如何设置定位
  • 混合销售怎么分别核算
  • window10自带商店下载位置
  • 公司为员工交的社保比例
  • 出售债券税费处理方法
  • 什么是冲帐?怎么个冲法?
  • 预缴和清缴的会计科目
  • 所得税 减半
  • vue set-cookie
  • 软件服务费应计入什么
  • 既简单又安全的小实验
  • 悬崖徒步
  • js查找数组所有符合条件数据
  • php图片库
  • 开会旅游的费用怎么算
  • php去掉最后一个逗号
  • 帝国cms建站教程
  • 营业收入的构成分析包括
  • 企业自产自用的产品需要缴纳增值税吗
  • access2016备注型
  • 企业享受政府补贴的具体方式
  • 私车公用的汽油费计入哪个科目
  • 摊余成本通俗易懂
  • 无形资产的处置损益
  • 企业广告费以后会涨吗
  • 其他应付款在借方资产负债表怎么填
  • 报关单金额大于出口发票金额
  • 小规模免征增值税的有哪些
  • 企业购买土地时土地款缴纳的耕地占用税入账
  • 实收资本实际缴纳要去税务局备案吗
  • 现金日记账的登记日期以什么日期为标准?
  • 应收账款坏账准备借贷方向
  • 快速插入大量数据的asp.net代码(Sqlserver)
  • windons10安装
  • win10图片修改
  • winxp系统介绍
  • win7文件夹选项在哪里打开
  • win10缺少文件怎么办
  • centos 做bond
  • win10注销系统会怎么样
  • Unity3d OnApplicationPause与OnApplicationFocus 判断游戏暂停还是重新启动
  • opengl api version
  • 根据当前目录下的文件
  • python迭代器iterator
  • shell脚本实现文件移动、复制等操作
  • actionscript与javascript的区别
  • 怎么做到开放
  • python中的魔法函数
  • 西安经开税务局电话号码
  • 大数据在税务稽查的应用
  • 广东地税局领导班子
  • 扬州税务学院住宿环境
  • 税务行业微信缴税项目是什么消费
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设