六、Providers 提供者
Providers 的主要任务是注入依赖关系DI。这意味着,对象可以彼此创建各种关系,并且对象的 “连接” 实例的功能可以在很大程度上委托给 Nest 运行时系统(这里使用了 IoC 容器)。
Provider 的本质就是一个用 @Injectable() 装饰器注释的类。它将提供很多的服务 Services,具体就是实现控制器需要的各种功能。
为了能够使用 Providers,需要现在 x.module.ts
模块中引入:
// x.module.ts 文件
import { Module} from '@nestjs/common';
import { XService } from './x.service';
import { X1Service } from './x1.service';
import { XController } from './x.controller';
@Module({
controllers: [XController],
// 也可以像控制器一样简写
providers: [{
// 注入自定义名称
provide: 'x-service', // 自定义名称
useClass: XService // 用到的类
}, {
// 注入自定义值
provide: 'PCs',
useValue: ['DELL', 'ASUS', 'LENOVO']
}, {
// 工程模式: 也可以返回异步结果
provide: 'factoryMode',
inject: [XService], // 需要先注入(在自定义名称中已注入)
async useFactory(XService: XService) {
return await new Promise(XService => {
setTimeout(() => { XService('delay') }, 2000)
})
}
}]
})
export class XModule {}
引入之后,就可以用该容器使用注入好的services(在控制器的构造器中当参数传入即可)。
// x.controller.ts 文件
import { Controller, Inject } from '@nestjs/common'
import { XService } from './x.service'
@Controller()
export class XController {
constructor(@Inject('x-service') private readonly x: XService,
@Inject('PCs') private readonly arr: string[],
@Inject('factoryMode') private readonly fn: any)) {}
}
这样,在控制器中就可以调用注入的services的方法。Providers 本质就是提供一些方法函数。
import { Injectable } from '@nestjs/common';
import { CreateXDto } from './dto/create-x.dto';
@Injectable()
export class XService {
create(createXDto: CreateXDto) { return '您添加了一个用户' }
method() { return '我是一个处理业务的方法' }
}