乐趣区

nodejs的Web开发框架的选择

node.js 的 Web 开发框架的选择?

这个问题貌似在其它的后端开发领域不存在。没错,我说的就是隔壁的 Java。我要是写 java 的应用,可以毫不犹豫的选择 Spring。但是 node 可选择的余地多的多。

现有 node 服务端框架

1. Express、Koa

express 框架肯定不用说了,写 node 服务这块的同学肯定是非常熟悉的框架了。我早期的时候也是 express 的粉丝。

优点:

express 的框架结构非常的简单。经过短暂的学习就可以用来开发一个项目。非常适合作为 node 新手的入门框架。

缺点:

开发阶段:

Express 的缺点也很明显,由于结构简单,自由度高。每个人会有不同的文件编排方式。前期设计阶段需要人工的把项目约定做好。但是团队来新人了,又要重新学习项目约定,无形中增加了学习成本。说到底还是缺乏项目的工程化约束。在项目的开发初期需要自己手工的搭建一些通用的脚手架代码,来方便的之后的开发工作。开发流程会拖的比较长。

运维阶段:

由于 node 单进程,js 主线程运行的机制。如果在 js 主线程中没有做好错误的处理。会导致进程意外退出的问题。这在项目运行阶段是不可接受的问题。需要进程守护的机制来保证程序的健壮性。Express 和 Koa 需要依赖第三方的工具来实现。如 PM2。讲道理这些功能应该是一个 web 开发框架应该具备的基础功能。

总结:

不管是 Express 还是 Koa 框架。还是处于比较简单的基于 http 模块的封装。在 Reuest 和 Response 这两个对象基础上进行扩展开发。我们业务开发团队需要的是稳定、快速的开发框架。实际开发中往往需要在 Express 和 Koa 的基础上封装大量的代码,来适应不同的业务场景,这对追求快速开发的互联网行业是不受欢迎的。

2. Egg.js

我在 2018 年 3 月份开始接触 egg 框架。发现这是一个具备较完善功能的 web 开发框架。

优点:

方便、好用、少写很多的脚手架级别的代码。专注于业务逻辑的开发。内建插件机制,兼容 koa 插件。约定大于配置。内置多进程管理。阿里巴巴开源。文档是中文的。估计没点自虐倾向的同学一般都会选择母语版本的文档来看吧。

缺点:

由于目前的使用层面还不够深入。除了对应用配置方式的不太满意外,没有发现大的开发痛点。项目开发实践下来,开发效率杠杠的。

总结:

估计写到这里,应该能看出我对 egg 框架的喜爱程度了。那么下面学习一下 egg 入门。

退出移动版