【发布时间】:2021-06-12 19:28:18
【问题描述】:
我有一个应用程序和一个库,两个独立的存储库。我的应用使用了我的库,而我的库包含一个执行 http 请求的服务。
我的应用程序部署到多个环境,我使用 Angular 的 environment.ts 文件来定义外部服务所在的位置。所有应用程序都通过网关提供服务,并位于同一个 window.location.origin。
ivy 被禁用,aot 被启用。
我的库公开了一个 forRoot,如下所示:
declarations: [
ToggleDirective
],
providers: [
ToggleService,
ToggleServiceConfig
],
exports: [
ToggleDirective
]
})
export class ToggleModule {
static forRoot(config: ToggleServiceConfig): ModuleWithProviders<ToggleModule> {
return {
ngModule: ToggleModule,
providers: [
{provide: ToggleServiceConfig, useValue: config }
]
};
}
}
我的 App 的 environment.ts 如下所示:
export const environment = {
...
togglesUrl: window.location.origin + '/release-toggling',
...
};
在我的 App 的 app.module 中,我是这样配置的:
...
const releaseToggleServiceConfig: ToggleServiceConfig = {
togglesUrl: environment.togglesUrl
};
...
@NgModule({
declarations: [AppComponent],
imports: [
CoreModule,
SharedModule,
...
ToggleModule.forRoot(releaseToggleServiceConfig)
],
...
})
export class AppModule {}
如果我硬编码 window.location.origin(本地,到 'localhost:4200'),那么它工作正常。显然,现阶段还不存在窗口。这可能与 aot 有关,但不幸的是,禁用 aot 不是一个选项。
正确传递 window.location.origin 的最佳模式/实践是什么。从技术上讲,在应用程序调用我的外部服务之前不需要它。
我对您的解决方案或建议感兴趣。这可能是很容易解决的问题,许多人以前都遇到过。
【问题讨论】:
-
只是为了调试和确认 window.location.origin 在这一点上实际上是空的。在你的
forRoot函数中,你可以console.log(window.location.origin)和console.log(config.togglesUrl)