Nest.js你学不会系列-初识Nest
前言
最近在学习研究 Nest 框架,但是在学习过程中除了参考翻阅官方文档外国内几乎没有多少资料能系统的讲解 Nest 的相关内容,所以打算想通过我自己学习的角度讲解下 Nest 框架,不知道能坚持多久,也可能有错误或遗漏的地方,欢迎大家批评指正。
下面我学习 Nest 的主要信息来源,在编写过程中还会有其他途径获取的信息会在文末给出:
-
GitHub: https://github.com/nestjs/nest
什么是 Nest
Nest 是一个用于构建高效,可扩展的 Node.js 服务器端应用程序的框架。它使用渐进式 JavaScript,内置并完全支持 TypeScript(但仍然允许开发人员使用纯 JavaScript 编写代码)并结合了 OOP(面向对象编程),FP(函数式编程)和 FRP(函数式响应编程)的元素。
Nest 框架底层 HTTP 平台默认是基于 Express 实现的,所以无需担心第三方库的缺失。 Nest 旨在成为一个与平台无关的框架。 通过平台,可以创建可重用的逻辑部件,开发人员可以利用这些部件来跨越多种不同类型的应用程序。 从技术上讲,Nest 可以在创建适配器 后使用任何 Node HTTP 框架。 有两个支持开箱即用的 HTTP 平台:express 和 fastify。
Nest 提供了一个开箱即用的应用程序架构,允许开发人员和团队创建高度可测试,可扩展,松散耦合且易于维护的应用程序。
在利用 NestJs 框架中,开发者可以体验到 NestJs 清晰的模块组织方式,隔离应用的各个工作区间;在各种工作区间都涉及不一样的设计模式,比如面向对象的SOLID原则在整个应用构建中的体现,AOP、DI、IoC 等在各个核心部件中的应用,OOP、FP、FRP 在各模块编码中的完美结合,都给开发中带来不一样的体验。
Nest 的特性
- 依赖注入容器
- 模块化封装
- 可测试性
- 内置支持 TypeScript
- 可基于 Express 或者 fastify
什么情况下使用 Nest
如果是一个简单的应用,其实用什么框架都无所谓,一个框架用 100 行代码实现,另一个用 80 行,区别不大。但涉及到企业级的应用,分分钟有上万行的代码,代码的组织结构就变得很重要了。如果代码拆分不合理,一个 JS 文件就有上千行的代码,后期的维护成本会非常的高。再考虑到复杂项目参与者众多,没有一个规范去约束的话,每个人写出来的代码风格迥异,协作起来会很难受。上文提到的几个框架对项目代码的架构要么是没约束,要么就是约束比较弱或者看起来很别扭。相比之下Nest的实现就很简洁,用起来很顺手。
安装
在安装前请确保您的操作系统上安装了 Node.js(> = 8.9.0)。
- 使用 CLI
$ npm i -g @nestjs/cli
$ nest new project-name
- 使用 git
$ git clone https://github.com/nestjs/typescript-starter.git project
$ cd project
$ npm install
$ npm run start
- 手动创建
$ npm i --save @nestjs/core @nestjs/common rxjs reflect-metadata
运行
$ nest start
然后我们访问 http://localhost:3000 就可以看到 Hello World! 了。
从上面的命令行中可以看出来整个项目是用 ts-node 跑起来的,这样的目的就是在开发环境节去了编译 .ts 的过程(实际上是 ts-node 在背后做了这个事情)。和其他 ts-node 项目不同的是,大多数 ts-node 运行在内存中,但是我们通过项目目录发现在 start 时会产生一个 dist 目录,哪怕是在开发环境其实我们访问的也是 dist 文件中的内容, 我们可以通过修改 tsconfig.json 中的 outDir 来修改输出的目录地址。
如果想要 watch 文件的修改建议使用 npm run start:dev
启动项目。
好了,今天这节就讲到这里,后续我们会针对 AOP、DI、IoC、OOP、FP、FRP 以及依赖注入容器和模块化封装等名称作单独的解释。