- 介绍:NestJS是Ts技术栈的后端框架,相当于Java中的springboot。
- 学习方法:与java技术体系进行对比学习。
- 学习目标:nest相关知识也是挺多,但对比学spring的时候,大部分在项目生产中都是套路化的,大部分也就是写业务逻辑,大部分 项目都很水的,代码生产下改改都行。所以入门阶段了解下重要概念,达到读懂以及编写CURD代码的程度即可。
- express:web框架,可用fastify代替(相当于spring与tomcat)
- global.d.ts:nestjs项目往往有这样一个文件类进行全局的类型声明,这个在Java中是没有的,原因在于在 Java 中,类型声明的方式与 TypeScript 不同。Java 是一种静态类型语言,类型信息通常在编译时处理,而不是在运行时。所以Java 中没有直接对应于
.d.ts
文件的概念。 - xxxx.module.ts:nestjs项目会有很多这种形式的module定义文件,Nestjs的代码组织方式是以模块为单位的,java没有,但总之就是一种管理和组织代码的设计方式,模块化也好,mvc分层化也好,java中类和包这类概念目的都差不多,都是为了解耦。
- 三层架构:这一点 Nestjs项目和springboot项目都一样
- 1 表现层/控制层/演示层(Web层/Controller层):请求处理/前端展示。(ps 如今大多前后分离,后端中这层分离出页面展示的功能了,只用于处理页面的请求)
- 2 逻辑层/应用层(Service层):实现业务逻辑,包含:验证、计算、业务规则等等。
- 3 数据层(DAO持久层):操作数据库。主要实现对数据的增、删、改、查。
- 实体类(实体层/Entity):贯穿于三层,在三层之间传递数据,往往与数据库的表对应
- 提供者:详细说下nest中的service层中用到的“提供者”概念,这个类似于spring中的bean
- @Injectable()` 类似java中的@Component,先注册。都是对类进行模块化管理。
- 用的时候再注入
constructor
类似java中的@Autowire - 提供者生命周期,可对照bean生命周期
- 管道的概念:nest中会经常提及这个概念,java中没用到过,但实际上linux很常用的一个命令
ps -ef|grep java
,里面的管道运算符|
就是这种思想,简单来说就是把程理解为数据的一种变换 “每一行的结果是下一行的输入”,这个过程就像是数据在一个个管道中穿越,即从从数据变换的角度去思考编程,所以这种思想也叫变换式编程。- 所有程序其实都是对数据的一种变换——将输入转换成输出。然而,当我们在构思设计时,很少考虑创建变换过程。相反,我们操心的是类和模块、数据结构和算法、语言和框架。
- 我们认为,从这个角度关注代码往往忽略了要点——我们需要重新把程序视为从输入到输出的一个变换。当这样做的时候,许多以前操心的细节就消失了。结构变得更清晰,错误处理更加一致,耦合下降了很多。
- 但java中虽然没有管道运算,但也可以达到类似的效果
- async关键词:spring中方法前没有 async这类关键词,但其实道理也一样,每个方法的调用都是异步的,而内部逻辑则是同步,也可以使用 Java 提供的线程池和异步处理机制来处理异步操作。
//ts后端代码示例
@Post()
async store(
@Body(
new ValidationPipe({
transform: true,
forbidUnknownValues: true,
validationError: { target: false },
groups: ['create'],
}),
)
data: CreatePostDto,
) {
return this.postService.create(data);
}
程序员提升&&转型交流群:954614622
如果是对3r教室感兴趣,可以找我有内部优惠