use*_*585 5 ngx-translate angular
我有一个使用 ngx-translate 的 angular 应用程序。以下版本:
"@angular/core": "5.2.6",
"@ngx-translate/core": "9.1.1",
"@ngx-translate/http-loader": "2.0.1"
Run Code Online (Sandbox Code Playgroud)
在 AppModule 类中,我添加了以下导入:
imports: [
.....
TranslateModule.forRoot({
loader: {
provide: TranslateLoader,
useFactory: (createTranslateLoader),
deps: [HttpClient]
}
})
......
]
.....
export function createTranslateLoader(http: HttpClient) {
return new TranslateHttpLoader(http, './assets/i18n/', '.json');
}
Run Code Online (Sandbox Code Playgroud)
我创建了一个导出 TranslateModule 的 SharedModule:
exports: [
// Modules
TranslateModule,
....
]
Run Code Online (Sandbox Code Playgroud)
一切都像魅力一样,除非我刷新放置在与应用程序模块不同的模块中的页面(导入 SharedModule)。在这种情况下,我需要导航回主页(在 AppModule 中编码),一旦我到达主页 ngx-translate 就会返回工作,我可以使用 ngx-translate 重新导航到其他页面。
有谁能够帮助我?提前致谢
更新 似乎问题与我刷新页面时未定义 translateService.currentLang 的事实有关。如果我通过 translateService.use(language) 以编程方式设置 ngOnInit 中的语言,它会起作用。如何通过设置默认的 currentLang 来避免在每个组件中手动设置对 currentLang 变量的检查?
我的共享模块中也有 translateModule,每个模块都在导入它。我在 sharedmodule 中导出了 TranslateModule。这样做,一切都按预期工作,每个模块都显示了它的翻译。也许尝试同样的事情,看看它是否适合你。
TranslateModule.forRoot({
loader: {
provide: TranslateLoader,
useFactory: (createTranslateLoader),
deps: [HttpClient]
}
Run Code Online (Sandbox Code Playgroud)
通过 app.module 在引导组件中通过 translateService 设置 useDefaultLanguage。这样,它是在顶层设置默认语言的唯一地方。
| 归档时间: |
|
| 查看次数: |
6039 次 |
| 最近记录: |