Как загрузить файлы json только при нажатии соответствующей языковой кнопки?
Я следую этому руководству, чтобы реализовать переводы в Angular2- он работает нормально, но я хотел бы загружать файлы json только при нажатии соответствующей языковой кнопки. Может кто-нибудь помочь?
// app/translate/translation.ts
import { OpaqueToken } from '@angular/core';
// import translations(I dont want to import all languages here)
import { LANG_EN_NAME, LANG_EN_TRANS } from './lang-en';
import { LANG_ES_NAME, LANG_ES_TRANS } from './lang-es';
import { LANG_ZH_NAME, LANG_ZH_TRANS } from './lang-zh';
// translation token
export const TRANSLATIONS = new OpaqueToken('translations');
// all translations
const dictionary = {
[LANG_EN_NAME]: LANG_EN_TRANS,
[LANG_ES_NAME]: LANG_ES_TRANS,
[LANG_ZH_NAME]: LANG_ZH_TRANS,
};
// providers
export const TRANSLATION_PROVIDERS = [
{ provide: TRANSLATIONS, useValue: dictionary },
];
// app/translate/translate.service.ts
import {Injectable, Inject} from '@angular/core';
import { TRANSLATIONS } from './translations'; // import our opaque token
@Injectable()
export class TranslateService {
private _currentLang: string;
public get currentLang() {
return this._currentLang;
}
// inject our translations
constructor(@Inject(TRANSLATIONS) private _translations: any) {
}
public use(lang: string): void {
// set current language
this._currentLang = lang;
}
private translate(key: string): string {
// private perform translation
let translation = key;
if (this._translations[this.currentLang] && this._translations[this.currentLang][key]) {
return this._translations[this.currentLang][key];
}
return translation;
}
public instant(key: string) {
// call translation
return this.translate(key);
}
}
import {NgModule} from '@angular/core';
import {TRANSLATION_PROVIDERS} from './translations';
import {TranslatePipe} from './translate.pipe';
import { TranslateComponent} from './translate.component';
import { CommonModule } from '@angular/common';
@NgModule({
imports: [
CommonModule
// PaginatorModule
],
declarations: [TranslatePipe,TranslateComponent],
providers: [
TRANSLATION_PROVIDERS
],
exports: [TranslateComponent,TranslatePipe]
})
export class TranslationModule {}
Обновление - я следовал этому руководству, чтобы добавить ngx-translate в свой проект. Но я не могу заставить его работать для загруженных дочерних модулей. Может кто-нибудь, пожалуйста, помогите мне в этом.
// мой код, который не работает - отлично работает в модуле приложения
import { NgModule } from '@angular/core';
import { LoginComponent } from './login.component';
import { LoginRoutes } from './login.routing';
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
import { CommonModule } from '@angular/common';
import {HttpClientModule, HttpClient} from '@angular/common/http';
import {TranslateModule, TranslateLoader} from '@ngx-translate/core';
import {TranslateHttpLoader} from '@ngx-translate/http-loader';
export function HttpLoaderFactory(http : HttpClient) {
return new TranslateHttpLoader(http);
}
@NgModule({
imports: [LoginRoutes,ReactiveFormsModule, CommonModule,
HttpClientModule,
TranslateModule.forChild({
loader: {
provide: TranslateLoader,
useFactory: HttpLoaderFactory,
deps: [HttpClient]
},
isolate: true
})],
declarations: [
LoginComponent
]
})
export class LoginModule {
constructor() {
}
}
1 ответ
Если вы используете @ngx-translate/core
Вы можете использовать LangChangeEvent
загрузить соответствующий языковой файл
import { TranslateService, LangChangeEvent } from '@ngx-translate/core';
Более подробную информацию можно найти здесь: https://www.npmjs.com/package/@ngx-translate/core