ich Stunden damit verbracht, es zum Laufen zu bringen . Schließlich musste ich dem Importabschnitt von app.module.ts
hinzufügen (in Ihrem Fall ist es vielleicht - home.module.ts
). Ich hoffe, das hilft.
Zuerst: Importieren HttpClientModule
Zweitens: Verwenden Sie HttpClient
anstelle von Http
.
So ist der Code wie folgt: app.module.ts
(In Ihrem Fall home.module.ts
)
import { NgModule } from '@angular/core';
import { IonicPageModule } from 'ionic-angular';
import { HomePage } from './home';
//translate related imports
import { TranslateModule, TranslateLoader } from '@ngx-translate/core';
import { TranslateHttpLoader } from '@ngx-translate/http-loader';
import { HttpClientModule, HttpClient } from '@angular/common/http';
export function createTranslateLoader(http: HttpClient) {
return new TranslateHttpLoader(http, './assets/i18n/', '.json');
}
@NgModule({
declarations: [
HomePage,
],
imports: [
IonicPageModule.forChild(HomePage),
HttpClientModule
TranslateModule.forRoot({
loader: {
provide: TranslateLoader,
useFactory: (createTranslateLoader),
deps: [HttpClient]
}
})
],
exports: [
HomePage
]
})
export class HomePageModule {}
In app.component.ts
fügen Sie diese Zeile in constructor
.
import {TranslateService} from '@ngx-translate/core';
...
translate.setDefaultLang('en');//So English language set
Und dann muss man zwei JSON
Dateien in ./assets/i18n/
Pfad erstellen.
en.JSON
{
"title": "Translation demo",
"text": "This is a simple demonstration app for {{value}}"
}
Dann mit PIPE
Filter wie dies in Ihrer Anwendung verwenden.
<h1>{{'title' | translate}}</h1>
ODER
<h1 [translate]="'title'"></h1>
Wir können auch eine parameter
passieren.
<h1>{{'text' | translate:{'value':'ngx-translate'} }}</h1>
ODER
<h1 [translate]="'text'" [translateParams]="{value: 'ngx-translate'}"></h1>
hier Lösung für mich gearbeitet https://stackoverflow.com/questions/44691028/ngx-translation-issue-with-ionic-3-app/44698964 – sonu
Sie annehmen können antwort, für dasselbe habe ich die antwort auf ionic community gepostet. – sonu