Prz*_*Wit 1 javascript dependency-injection node.js typescript nestjs
在 NestJS 中我有自定义记录器:
import { Injectable, Logger, Scope } from '@nestjs/common';
@Injectable({ scope: Scope.TRANSIENT })
export class LoggerService extends Logger {
log(message: any) {
super.log(message);
}
error(message: any) {
super.log(message);
}
warn(message: any) {
super.log(message);
}
debug(message: any) {
super.log(message);
}
verbose(message: any) {
super.log(message);
}
setContext(context: string) {
super.context = context;
}
}
Run Code Online (Sandbox Code Playgroud)
它在全球注册:
import { Global, Module } from '@nestjs/common';
import { LoggerService } from './logger.service';
@Global()
@Module({
providers: [LoggerService],
exports: [LoggerService],
})
export class LoggerModule {}
Run Code Online (Sandbox Code Playgroud)
有没有办法以某种方式在服务构造函数中传递注入上下文,并避免在每个服务中执行 logger.setContext(context) - 而只是在LoggerService构造函数中设置它?
现在的用法示例:
constructor(private logger: LoggerService) {
this.logger.setContext(ClassName.name);
}
Run Code Online (Sandbox Code Playgroud)
预期用途:
constructor(private logger: LoggerService) {}
Run Code Online (Sandbox Code Playgroud)
当你这样做时private logger: LoggerService
,就没有机会拨打这个.setContext(Service.name)
电话了。
你可以做的是这样的:
@Logger(Service.name) private logger: LoggerService
如何?阅读本文:高级 NestJS:动态提供程序