当前位置: 首页 > news >正文

1.8 providers

  1. 生成providers

nest g service <name>
  1. providers的注入方式

构造函数注入

@Injectable()
export class KeywordService {constructor(private readonly httpService: HttpService,private readonly pro: ProService,) {}
}

@Inject()注入

export class KeywordController {@Inject()private readonly httpService: HttpService;@Inject()private readonly keywordService: KeywordService;
}
  1. providers注册

@Module({imports: [HttpModule.register({timeout: 5000,maxRedirects: 5,baseURL: 'http://localhost:3000',}),ProModule,],controllers: [KeywordController],providers: [KeywordService],
})
export class KeywordModule {}
  1. 创建providers

a. 使用@Injectable()注解

b. providers完整写法

在module中注册时,一般使用简写,下面是providers的完整写法

providers: [{provide: CatsService,useClass: CatsService,},
];

c. 值提供者/value providers

//mock.ts
export class Mock {getHello(): string {return 'hello world';}
}//pro.module.ts
@Module({providers: [{provide: ProService,useValue: new Mock(),},],exports: [ProService],
})//Mock类要和ProService类拥有同样的方法,即Mock和ProService都有一个getHello()方法,则nest在解析时,会用Mock的getHello()方法替换掉ProService的getHello()方法

d. 非类提供者/Non-class-based provider tokens

//pro.module.ts
import { Mock } from './mock';
@Module({providers: [{provide: 'connect',useValue: new Mock(),},],exports: ['connect'],
})
export class ProModule {}
//mock.ts
export class Mock {getHello(): string {return 'hello world';}
}//注入
import { Mock } from '../pro/mock';
@Controller('keyword')
export class KeywordController {
@Inject('connect')private readonly mock: Mock;
}

e. 类提供者/useClass

import { ProService } from './pro.service';
@Module({providers: [{provide: 'ProService',useClass: ProService,},],exports: ['ProService'],
})
export class ProModule {}

或者用三元操作符来判断,返回特定的提供者

import { Module } from '@nestjs/common';
import { ProService } from './pro.service';
import { FactoryService } from './factory.service';let a;@Module({providers: [{provide: 'CONNECTION',useClass: a ? ProService : FactoryService,},],exports: ['CONNECTION'],
})
export class ProModule {}

f. 工厂提供者/factory providers

import { Module } from '@nestjs/common';
import { FactoryService } from './factory.service';@Module({providers: [FactoryService, //必须引入,或者直接引入FactoryModule{provide: 'CONNECTION',useFactory: (fac: FactoryService) => {return String(fac.getHello());},inject: [FactoryService],},],exports: ['CONNECTION'],
})
export class ProModule {}

或者

@Module({imports: [FactoryModule],providers: [{provide: 'CONNECTION',useFactory: (fac: FactoryService) => {return String(fac.getHello());},inject: [FactoryService],},],exports: ['CONNECTION'],
})

或者

import { Module } from '@nestjs/common';
import { FactoryService } from './factory.service';
import { FactoryModule } from './factory.module';
const connectionFactory = {provide: 'CONNECTION',useFactory: (optionsProvider: FactoryService) => {const options = optionsProvider.getHello();return String(options);},inject: [FactoryService],
};@Module({imports: [FactoryModule],providers: [connectionFactory, FactoryService],exports: [connectionFactory],
})

或者直接提供值

import { Module } from '@nestjs/common';
import { FactoryService } from './factory.service';
import { FactoryModule } from './factory.module';
const config = {data: {a: 1,b: 2,},
};
const connectionFactory = {provide: 'CONNECTION',useFactory: () => config,
};@Module({imports: [FactoryModule],providers: [connectionFactory, FactoryService],exports: [connectionFactory],
})

g.别名提供者

import { Module } from '@nestjs/common';
import { FactoryService } from './factory.service';
import { FactoryModule } from './factory.module';const TestService = {provide: 'Test',useExisting: FactoryService,
};
//TestService和FactoryService是同一个提供者
@Module({imports: [FactoryModule],providers: [FactoryService, TestService],exports: [TestService, FactoryService],
})

h.导出提供者

//可以导出令牌,也可以导出整个对象
exports: [‘Test', FactoryService]

i. 异步提供者

//在实例化依赖于(注入)这样一个提供程序的任何类之前,Nest将等待承诺的解决
{provide: 'ASYNC_CONNECTION',useFactory: async () => {const connection = await createConnection(options);return connection;},
}

http://www.lryc.cn/news/9777.html

相关文章:

  • 如何编写一个基本的 Verilog Module(模块)
  • 让乔布斯想要「发动核战争」的 Android,为何成了占有率最高的系统?
  • FPGA开发软件(vivado + modelsim)环境搭建(附详细安装步骤+软件下载)
  • TypeScript 学习之类型
  • 基于MATLAB计算MIMO信道容量(附完整代码与分析)
  • CSDN城市开发者联盟、C友会期待你的加入
  • 【新2023】华为OD机试 - 吃火锅(Python)
  • 类似LeetCode的登录页面(小程序版)
  • CUDA的统一内存
  • MySQL-其他函数(补充)
  • MySQL Study Notes Design in 2023
  • C++ 修改防火墙firewall设置(Windows)
  • Spring 入门教程详解
  • day43【代码随想录】动态规划之一和零、完全背包理论基础
  • GEE学习笔记 七十八:干涸的洪泽湖
  • 双指针【灵神基础精讲】
  • tushare量化数据库模块怎么分析?
  • 模型转换 PyTorch转ONNX 入门
  • 【深度学习】激活函数
  • 【新2023】华为OD机试 - 数字的排列(Python)
  • [oeasy]python0085_ASCII之父_Bemer_COBOL_数据交换网络
  • volatile,内存屏障
  • 【ESP 保姆级教程】玩转emqx MQTT篇① —— 系统主题、延迟发布、服务器配置预算、常见问题
  • 第48讲:SQL优化之ORDER BY排序查询的优化
  • [Datawhale][CS224W]图机器学习(三)
  • 2023版最新最强大数据面试宝典
  • CSS 中的 BFC 是什么,有什么作用?
  • 总结在使用 Git 踩过的坑
  • 从 HTTP 到 gRPC:APISIX 中 etcd 操作的迁移之路
  • 【C语言每日一题】——倒置字符串