我一直在基于 nodejs
模块为 nestjs
开发一个包装器模块。我创建了一个静态 forRoot
方法来获取配置。我在 forRoot
方法中创建了这样一个 prodiver:
const MyProvider = {
provide: PROVIDER_TOKEN,
useValue: new MyClass(options),
};
我也导出它,所以在消费者模块中很容易注入(inject)它以访问nodejs模块的所有方法。此外,我可以将该模块的所有方法包装到我的服务方法中。因此,以下代码使我可以访问主模块的实例:
constructor(@Inject(PROVIDER_TOKEN) private readonly myClass: MyClass) {}
然后我决定创建一个 forRootAsync
方法,该方法可以使用 useFactory
处理获取配置。现在这是我在 forRootAsync
方法中的提供程序:
const MyProvider= {
provide: PROVIDER_TOKEN,
useFactory: optionsAsync.useFactory,
inject: optionsAsync.inject || []
};
但是这一次,如果我将 PROVIDER_TOKEN
注入(inject)到服务中,这只是配置对象(我从消费者模块传递的)。所以我想我应该在构造函数中创建实例。也许是这样的:
constructor(@Inject(PROVIDER_TOKEN) private readonly myClass) {
if(!this.myClass typeof MyClass) {
this.myClass = new MyClass(this.myClass);
}
}
这样,我就无法通过注入(inject) PROVIDER_TOKEN
token 来访问消费者模块中主模块的实例。目标是访问该模块的所有方法,而不必包装所有方法。有什么想法吗?
最佳答案
我们应该通过两个提供商来处理这个问题。在第一个中,我们传递工厂提供者如下:
{
provide: HTTP_MODULE_OPTIONS,
useFactory: options.useFactory,
inject: options.inject || [],
};
然后我们创建另一个提供程序来注入(inject)第一个提供程序(nestjs 在此时解决依赖关系):
{
provide: AXIOS_INSTANCE_TOKEN,
useFactory: (config: HttpModuleOptions) => Axios.create(config),
inject: [HTTP_MODULE_OPTIONS],
},
这是example .
关于Nestjs 在 forRootAsync 中包装外部模块并注入(inject)实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67157572/