Ionic3找不到管道“翻译”

时间:2018-06-27 08:25:04

标签: angular ionic-framework ionic3 ngx-translate

嗨,自从我尝试解决这个问题没有成功以来已经有好几天了。 当我尝试使用管道翻译时,出现此错误

Error: Uncaught (in promise): Error: Template parse errors:
The pipe 'translate' could not be found ("
<ion-content padding>
<h2>{{[ERROR ->]"HELLO" | translate }}</h2>
</ion-content>
"): ng:///AdminPannelPageModule/AdminPannelPage.html@11:8

我正在使用角度5。

这些是我用于翻译的版本

"@ngx-translate/core": "^9.1.1",
"@ngx-translate/http-loader": "^2.0.1",

Npm安装

npm install @ngx-translate/core @ngx-translate/http-loader --save

这是我的Home.html页面

<h2>{{"HELLO" | translate }}</h2>

用于翻译的JSON文件:

assets/i18n/en.json

{
"HELLO": "hello"
}

assets/i18n/it.json

{
"HELLO": "ciao"
}

在导出中,我使用export function setTranslateLoader (http: HttpClient)而不是使用export function setTranslateLoader (http: Http),因为如果没有,则会出现以下错误:Argument of type 'Http' is not assignable to parameter of type 'HttpClient '. Property 'handler' is missing in type 'Http'.

app.module.ts中有我的导入

import { TranslateModule, TranslateLoader } from '@ngx-translate/core';
import { HttpClientModule, HttpClient } from '@angular/common/http';
import { TranslateHttpLoader } from '@ngx-translate/http-loader';

export function setTranslateLoader(http: HttpClient) {
return new TranslateHttpLoader(http, './assets/i18n/', '.json');
}


@NgModule({
imports: [
HttpClientModule,
IonicModule.forRoot(MyApp),
TranslateModule.forRoot({
  loader: {
    provide: TranslateLoader,
    useFactory: (setTranslateLoader),
    deps: [HttpClient]
  }
}),
],

这是我的app.component.ts构造函数

constructor(..., translate: TranslateService) {
     translate.setDefaultLang('en');
     ...
}

1 个答案:

答案 0 :(得分:10)

我们可以看到您有一个子模块AdminPannelPageModule,其中实际上引发了错误。您还需要在该模块中标记TranslateModule,但是跳过forRoot()。因此,在您的AdminPannelModule中:

imports: [
  ....
  TranslateModule
],