内容简介:在项目建立初期引入一些最佳实践可以避免后期大量复杂的重构工作,本文总结了在使用Node JS构建Web服务时的一些最佳实践,同时涉及的具体的操作步骤。所谓脚手架,就是在初始化代码库时,脚手架可以帮助自动生成一些代码和项目结构,注入一些框架。对于一个NodeJS项目,不需要我们从npm init初始化起,自己一步步安装一些依赖。Express是目前最流行的NodeJS web框架。全局安装一个express-generator,用来初始化express项目。
在项目建立初期引入一些最佳实践可以避免后期大量复杂的重构工作,本文总结了在使用Node JS构建Web服务时的一些最佳实践,同时涉及的具体的操作步骤。
一、使用初始化脚手架
所谓脚手架,就是在初始化代码库时,脚手架可以帮助自动生成一些代码和项目结构,注入一些框架。对于一个NodeJS项目,不需要我们从npm init初始化起,自己一步步安装一些依赖。
Express命令
Express是目前最流行的NodeJS web框架。全局安装一个express-generator,用来初始化express项目。
-
全局安装命令:
npm install express-generator -g
-
新建一个名为 hello-express 项目:
express hello-express
使用Swagger脚手架
当使用NodeJS 开发Web API时,强烈建议使用Swagger进行API构建与管理,以及提供API文档服务。全局安装swagger命令也可以实现初始化一个swagger项目。swagger命令可以让你在浏览器上实时直接编辑你的API定义和调试API。
初始化swagger项目
npm install swagger -g swagger project create hello-swagger
. ├── README.md ├── api │ ├── controllers │ │ ├── README.md │ │ └── hello_world.js │ ├── helpers │ │ └── README.md │ ├── mocks │ │ └── README.md │ └── swagger │ └── swagger.yaml ├── app.js ├── config │ ├── README.md │ └── default.yaml ├── package-lock.json ├── package.json └── test └── api ├── controllers │ ├── README.md │ └── hello_world.js └── helpers └── README.md 复制代码
实时编辑和语法校验
- 启动在线编辑:
swagger project edit
, 此时会打开系统浏览器,在浏览器中可以直接编辑swagger文档,并进行实时语法检查,同时浏览器里面的编辑变更会回写到代码。
在线调试API
上图右侧部分,就是类似于 postman
的API调试工具。
二、Swagger文档服务
Swagger是一个最流行的的API构建与管理工具,在各种语言和框架都有相应的库可以支持,同时安装swagger-ui扩展进行API文档管理和在线调试。 其遵循OpenAPI标准,OpenAPI定义了诸如路由转发、参数定义与校验等一整套API规范。
- OpenAPI规范文档: swagger.io/specificati…
- 在线API编辑器预览:editor.swagger.io
发布swagger文档
上面的swagger命令适合在本地编辑、调试使用,当在产品(Production)环境发布文档服务时,适合引入 swagger UI 中间件
app.use(SwaggerUi(swaggerExpress.runner.swagger)); 复制代码
访问 http://localhost:10010/docs/#/ 即可查看API文档:
-
在线预览:petstore.swagger.io/
-
完整代码如下:
SwaggerExpress.create(config, function (err, swaggerExpress) { if (err) { throw err; } // install middleware app.use(SwaggerUi(swaggerExpress.runner.swagger)); swaggerExpress.register(app); const port = 10010; app.listen(port); if (swaggerExpress.runner.swagger.paths['/hello']) { console.log('try this:\ncurl http://127.0.0.1:' + port + '/hello?name=Scott'); } }); 复制代码
三、启用ES6 JS语法
ECMAScript 是 JS 的语言标准,ES6是新的JS语法标准。在没有其它配置的情况下使用ES6语法会出现一下错误。我们需要引入babel做语法转换。
import SwaggerExpress from 'swagger-express-mw'; ^^^^^^^^^^^^^^ SyntaxError: Unexpected identifier at Module._compile (internal/modules/cjs/loader.js:760:23) at Object.Module._extensions..js (internal/modules/cjs/loader.js:827:10) 复制代码
什么是babel
Babel 是一个 JavaScript 编译器,工具链,主要用于将 ECMAScript 2015+ 版本的代码转换为向后兼容的 JavaScript 语法,以便能够运行在当前和旧版本的浏览器或其他环境中。更多文档可参考:www.babeljs.cn/docs/
如何配置?
- 安装依赖:
npm install -D @babel/core @babel/cli @babel/preset-env @babel/node 复制代码
- 在根目录创建.babelrc文件,内容如下
{ "presets": ["@babel/preset-env"] } 复制代码
- 使用babel-node命令代替node
"scripts": { "start": "npm run prod", "server": "node ./app.js" // -> "babel-node ./app.js" } 复制代码
如何处理已有的非ES6项目?
安装一个npm module cjs-to-es6
可以做一些简单的ES6语法转化:
npm install -g cjs-to-es6 复制代码
参考资料
- www.babeljs.cn/docs/
- How to enable ES6 (and beyond) syntax with Node and Express: medium.freecodecamp.org/how-to-enab…
四、文件变动监听并自动重启服务
每次修改代码时我们需要重启Express来查看效果, nodemon
可以在指定的文件发生修改后,帮助我们自动重启服务,提高开发效率。
npm i -D nodemon
{ "exec": "npm run dev", "watch": ["src/*", "public/*"], "ext": "js, html, css, json" } 复制代码
- 参考文档可以更多配置: github.com/remy/nodemo…
五、使用ES Lint做代码风格扫描
ES Lint是一款代码风格扫描工具,尤其是在团队开发时可以帮助我们规范我们的代码风格,并提供与IDE的集成做到代码纠错。
- 安装eslint
npm i -D eslint
- 参考文档: eslint.org/docs/user-g…
六、在代码提交时触发指定操作
常常有这样的场景,持续集成要求我们在提交代码之前测试在本地是可以通过的。这个时候我们可以在注册“钩子”的方式,在代码提交之前在本地运行测试,如果测试不通过则不允许提交。那么使用 husky
可以这一需求:
- husky文档: github.com/typicode/hu…
例子1: 在git push 之前运行测试
"husky": { "hooks": { "pre-push": "npm run coverage && npm run pact:test" } }, 复制代码
例子2: 在git commit 之前运行代码风格检查和自动纠正
"husky": { "hooks": { "pre-commit": "npm lint" } }, 复制代码
七、开启Gzip压缩提高服务响应速度
开启gzip压缩可以显著提高HTTP的服务的访问速度,安装 compression
中间件可以非常方便地启用。
import compression from 'compression'; ... app.use(compression()); 复制代码
以上所述就是小编给大家介绍的《新建NodeJS Web项目的几个最佳实践》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- idea新建springboot项目
- kubelet 源码分析:pod 新建流程
- Linux VG扩展新增硬盘并新建文件系统
- 合并本地脚手架工程与github新建工程
- TiDB是如何新建一张表的? 原 荐
- mysql迁移之新建用户、备份还原数据库
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Thirty-three Miniatures
Jiří Matoušek / American Mathematical Socity / 2010-6-18 / USD 24.60
This volume contains a collection of clever mathematical applications of linear algebra, mainly in combinatorics, geometry, and algorithms. Each chapter covers a single main result with motivation and......一起来看看 《Thirty-three Miniatures》 这本书的介绍吧!