位置: 编程技术 - 正文

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)构建前后端分离实例(带跨域)

  • 进项税额比销项税额多怎么填申报表
  • 什么是试算平衡?如何进行试算平衡
  • 免费样品需要交印花税吗
  • 收到投资款的会计科目
  • 个人房租费收入怎么做账
  • 个人转让商铺个人所得税核定征收
  • 应收账款融资的优缺点
  • 债务清偿抵充的案例
  • 上个月未抵扣忘记做进项会计分录
  • 普通发票可以改明细吗
  • 缴纳增值税的计税依据
  • 建筑企业发生的招标代理费一般计入
  • 2018税务金四发展预测会有哪些?
  • 取得稳岗补贴后怎么办
  • 增值税税控系统专用设备
  • 公司招待用烟酒的管理
  • 股东增资印花税税目
  • 退回工资能退个税吗
  • 财务费用明细科目怎么写
  • 税务局收到企业发票
  • 个人出租房屋交税如何计算
  • 库存现金可以做中转科目嘛为什么
  • 委托代销商品会计分录按成本还是售价
  • 出售单位车辆如何处理业务?
  • windows10如何切屏
  • 已经上传的红字怎么修改
  • u盘文件全都变成快捷方式怎么办
  • 深入浅出stm8
  • linux小技巧
  • mssvr.exe - mssvr是什么进程 什么用
  • 工程材料怎么开票
  • 企业财务管理的对象是什么
  • 公司挂靠社保的人员需要申报个人所得税吗?
  • 建筑工程房屋租赁费属于什么费用
  • 饿了么指定单
  • 长期借款利息的账务处理涉及的会计科目有
  • vue引入网络js
  • ChatGPT 的 10 种集成模式:从开源 AI 体验平台 ClickPrompt 中受到的启发
  • cpu power management设置
  • 没有什么盈利的公司应该进吗
  • 代扣代缴境外增值税时间
  • 2022年最新装修风格
  • 无形资产摊销年限
  • 期初和期末余额是什么意思
  • 公司支付宝账户怎么管理
  • 汇算清缴纳税调整需要做账吗
  • 房屋租赁物业费谁承担
  • 企业投资股权收益如何征税
  • 砖厂的会计分录有哪些
  • 应收账款未收到是否要交税
  • 预付账款年底怎么调账
  • 保险返点返20怎么算
  • 出口退税账务处理
  • 行政事业单位福利费提取比例
  • 应付账款和预付账款都属于负债类科目
  • 经费收入经费支出怎样记账
  • 收到供应商赠送原材料
  • 商业企业固定资产一次性扣除
  • sql like多个
  • mysql无法配置
  • 屏幕右下角显示A2
  • centos下载教程2020
  • win8.1的开始菜单在哪
  • ubuntu系统怎么进入命令行
  • Windows(win7/win8/xp/2003)进入安全模式方法详细汇总
  • macos vmware
  • win8和win10怎么共享文件
  • win7系统开机登录不了怎么修复
  • 批处理常用命令总结
  • eclipse4.9.0安装windowbuilder
  • js判断pc还是移动
  • unity导入max文件
  • unity shader cull off
  • 理解js绑定事件是什么
  • python编写一个模块
  • 广东税务个人账号注销后会怎样
  • 佛山市地方税务局与国家税务局合并没有
  • 贵州房产备案信息查询网
  • 八戒财税主要做什么
  • 银行最新税率
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设