Angular6-使用ngx-translate

时间:2018-09-04 11:29:14

标签: angular typescript frontend angular6 ngx-translate

我想在前端使用ngx-translate在应用程序加载时动态加载翻译。

我的后端返回JSON格式的响应,例如:

{
   "something: "something"
}

我想在我的TranslateLoader上使用该输出,而不是本地en.json文件。

有什么办法可以实现?

TL; DL:我想调用'http://localhost:xxxx/api/translation/EN'以获取翻译的JSON响应并将其加载到TranslateHttpLoader

2 个答案:

答案 0 :(得分:4)

您可以创建工厂:

export function httpLoaderFactory(http: HttpClient) {
  return new TranslateHttpLoader(http, "http://localhost:xxxx/api/translation/", "");
}

并在您的@NgModule导入中使用它:

TranslateModule.forRoot({
  loader: {
    provide: TranslateLoader,
    useFactory: httpLoaderFactory,
    deps: [HttpClient]
  }
}),

答案 1 :(得分:2)

我们可以在自定义加载程序类中使用TranslateLoader提供程序

In Module :

export class CustomLoader implements TranslateLoader {

  constructor(private http: Http) {}

  public getTranslation(lang: String): Observable<any> {
    return this.http.get(URL).map(
      (res: any) => {
        return res;
      }
    );

  }
}

@NgModule({
  imports: [
    TranslateModule.forRoot({
      provide: TranslateLoader,
      useClass: CustomLoader,
      // useFactory: (createTranslateLoader),
      deps: [Http]
    })
  ]
}) 

在组件中:

 constructor(private _translate: TranslateService){}

 const transText = this._translate.instant('something');