nest学习

本文详细介绍了NestJS框架中创建项目、模块、控制器和服务的命令,处理流程,以及依赖注入、IoC控制反转和装饰器模式的应用。强调了模块化和降低耦合的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

常用脚手架命令

  1. 创建项目
nest new [project]
  1. 创建模块
nest g mo [name] --no-spec
  1. 创建控制器
nest g co [name] --no-spec
  1. 创建服务
nest g s [name]
全称别名
namealias
applicationapplication
classcl
configurationconfig
controllerco
decoratord
fitterf
gatewayga
guardgu
interceptorin
interfaceinterface
middlewaremi
modulemo
pipepi
providerpr
resolver
services
librarylib
sub-appapp

处理流程

发送http请求,根据路由匹配对应的控制器
控制器去访问服务层
服务层对数据进行操作
在这里插入图片描述

模块文件解析

import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';

@Module({
  imports: [], // 注册的其它模块
  controllers: [AppController], //该模块提供的控制器
  providers: [AppService], // 该模块提供的服务
  exports: [], // 别的模块要使用该模块中的某几个方法,就要在这里对外暴漏
})
export class AppModule {}

controllers文件解析

写路由,注入路由对应的服务,将注入的服务执行

// 路由地址
@Controller()
export class AppController {
  // 依赖服务注入
  constructor(private readonly appService: AppService) {}
  @Get()
  getHello(): string {
    // 可以使用其它模块的服务
    return this.appService.getHello();
  }
}

service

主要是做数据交互

@Injectable()
export class AppService {
  getHello(): string {
    return 'Hello hogsen';
  }
}

IOC控制反转与DI 依赖注入

假设我有两个模块,moduleAmoduleB,现在我要在模块A中使用模块B的服务我应该怎么写。
第一种写法
在这里插入图片描述
我直接在模块A中调用模块B,这样写是可行的对吧,但是会有一个很严重的问题,A,B模块具有强耦合关系,
模块B对于模块A具用很强的副作用。模块A不纯,它有很强的副作用。
那么如何去减少副作用,让代码更健壮
第二种写法
在这里插入图片描述

跟发布订阅模式差不多,模块之间并没有什么依赖关系,IOC容器负责收集依赖,以及对外提供服务。模块对外提供一个接收服务的接口。尽量确保模块是纯的没有副作用的。在前端中属于组件通信的一种方式。

class Container {
  moudle;
  constructor() {
    this.moudle = {};
  }
  // 收集依赖
  service(key: string, moudle) {
    this.moudle[key] = moudle;
  }
  // 对外提供服务
  provide(key: string) {
    return this.moudle[key];
  }
}

class Teacher {
  name;
  constructor(name) {
    this.name = name;
  }
  static teach(stu) {
    console.log(`${stu}读书`);
  }
}
class Student {
  name;
  constructor(name) {
    this.name = name;
  }
  inject(fn) {
    fn(this.name);
  }
}
const container = new Container();
// 收集依赖
container.service('te', Teacher);
container.service('stu', Student);
const hogsen = new Student('hogsen');
// 注入容器提供的服务
hogsen.inject(container.provide('te').teach);

装饰器模式

在nest中大量使用了装饰器,所以我们必须要理解装饰器模式
typescript中装饰器分为

  1. 类装饰器ClassDecorator
    declare type ClassDecorator = <TFunction extends Function>(target: TFunction) => TFunction | void;
    接收一个参数target表示构造函数
  2. 属性装饰器PropertyDecorator
    declare type PropertyDecorator = (target: Object, propertyKey: string | symbol) => void;
    它接收两个参数,target是原型对象,propertyKey 就是该属性
  3. 方法装饰器MethodDecorator
    declare type MethodDecorator = <T>(target: Object, propertyKey: string | symbol, descriptor: TypedPropertyDescriptor<T>) => TypedPropertyDescriptor<T> | void;
    接收原型对象,该方法名,属性描述符对象
  4. 参数装饰器ParameterDecorator
    declare type ParameterDecorator = (target: Object, propertyKey: string | symbol | undefined, parameterIndex: number) => void;
    接收原型对象,该方法名,参数位置

nest 中的装饰器

参数装饰器

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值