ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

NestJs学习之旅(1)——快速开始

2021-04-11 21:53:34  阅读:233  来源: 互联网

标签:10 之旅 Nest ts 学习 json 2019 NestJs


经过NodeJs系列课程和Typescript系列课程,终于开始了激动人心的NestJs学习之旅。

欢迎持续关注NestJs之旅系列文章

介绍
Nest(或NestJS)是一个用于构建高效,可扩展的Node.js服务器端应用程序的框架。它使用渐进式JavaScript,内置并完全支持TypeScript(但仍然允许开发人员使用纯JavaScript编写代码)并结合了OOP(面向对象编程),FP(功能编程)和FRP(功能反应编程)的元素。

import { Controller, Get } from '@nestjs/common';
@Controller('cats')
export class CatsController {
@Get()
findAll(): string {
return 'This action returns all cats';
}
}

熟悉Java的同学应该有似曾相识的感觉,SpringBoot中大量使用注解来简化开发。现在,使用基于ES6装饰器构建的NestJs框架,你也可以做到!

优缺点
先说说优点吧:

  • 完美支持Typescript,因此可以使用日益繁荣的TS生态资源

  • 兼容express中间件,降低造轮子成本

  • 完美支持响应式编程框架rxjs

  • 完美支持依赖注入

  • 模块化思想,方便开发以及后期维护

  • 使用装饰器简化开发,减少样板代码

  • 组件化设计,解决Node.js无全栈框架约束的现存问题

当然,”缺点”也是有点的,不过熟练之后这些都不是缺点:

  • 基于TS导致的语言门槛

  • 代码设计上对模块化/组件化思想有一定要求

第一个NestJs应用
使用NestJs的命令行工具,可以简化项目的创建以及项目文件的创建。

  1. npm install -g @nestjs/cli安装命令行工具

  2. nest new 项目名称初始化项目

初始化完毕后可以看到一个完整的项目结果,目录如下(忽略node_modules):


├── README.md                       自述文件
├── nest-cli.json                   NestJs项目配置
├── package.json                    npm文件
├── src                             项目源码
│   ├── app.controller.spec.ts      控制器测试文件
│   ├── app.controller.ts           控制器类
│   ├── app.module.ts               模块类
│   ├── app.service.ts              服务类
│   └── main.ts                     项目入口文件
├── test                            测试目录
│   ├── app.e2e-spec.ts             应用e2e测试
│   └── jest-e2e.json               jest e2e测试配置
├── tsconfig.build.json             生产环境Typescript所用
├── tsconfig.json                   开发环境Typescript配置
├── tslint.json                     tslint配置
└── yarn.lock                       yarn锁文件

NestJs有几大类文件是主要的是下面几种,其他类型的文件在后续课程会讲解;

  • module 模块声明(这是NestJs的一个亮点,有点DDD的思想)

  • controller 控制器(负责接收数据,返回响应)

  • service 服务(主要业务逻辑)

使用npm run start来运行项目。终端输出如下:


[Nest] 2986   - 08/19/2019, 10:29 AM   [NestFactory] Starting Nest application...
[Nest] 2986   - 08/19/2019, 10:29 AM   [InstanceLoader] AppModule dependencies initialized +22ms
[Nest] 2986   - 08/19/2019, 10:29 AM   [RoutesResolver] AppController {/}: +12ms
[Nest] 2986   - 08/19/2019, 10:29 AM   [RouterExplorer] Mapped {/, GET} route +9ms
[Nest] 2986   - 08/19/2019, 10:29 AM   [NestApplication] Nest application successfully started +6ms

一般来说,看到successfully就可以认为启动成功了。启动失败的话可以根据错误提示进行处理,比较多的情况可能是端口占用导致的错误。

打开浏览器访问http://localhost:3000即可看到输出Hello World!。

To Be Continued
下一期将介绍Controller,欢迎持续关注!

标签:10,之旅,Nest,ts,学习,json,2019,NestJs
来源: https://blog.51cto.com/u_15127543/2699965

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有