本文只针对ngx-translate/core 6.x版本,如果你使用的是5.x或者更低的版本,请参照以下链接。
https://github.com/ngx-translate/core/blob/fb02ca5920aae405048ebab50e09db67d5bf12a2/README.md
安装
首先需要安装npm依赖:
=4.3
npm install @ngx-translate/http-loader@0.1.0 --save // 针对Angular<4.3
这里需要注意,如果你使用的Angular版本是 Angular <4.3,那么需要安装http-loader@0.1.0版本。
因为0.1.0以后的版本TranslateHttpLoader构造函数的第一个参数改为HttpClient类型,而非Http类型。
1、引入TranslateModule模块
首先需要在你项目的root NgModule中引入TranslateModule.forRoot()模块。一般在项目中默认命名为app.module.ts。
rush:js;">
import {NgModule} from '@angular/core';
import {
browserModule} from '@angular/platform-
browser';
import {HttpClientModule,HttpClient} from '@angular/common/http';
import {TranslateModule,TranslateLoader} from '@ngx-translate/core';
import {TranslateHttpLoader} from '@ngx-translate/http-loader';
import {AppComponent} from './app';
export function createTranslateLoader(http: HttpClient) {
return new TranslateHttpLoader(http,'./assets/i18n/','.json');
}
@NgModule({
imports: [
browserModule,HttpClientModule,TranslateModule.forRoot({
loader: {
provide: TranslateLoader,useFactory: (createTranslateLoader),deps: [HttpClient]
}
})
],bootstrap: [AppComponent]
})
export class AppModule { }
这里使用了TranslateHttpLoader 来加载我们定义好的语言文件。"/assets/i18n/[lang].json"这里的lang就是当前正在使用的语言。
注意:如果当前采用的是AOT编译方式或者是ionic2工程,那么useFactory对应的必须是一个export的自定义方法而非内联方法。
即以下这种方式是不被允许的:
new TranslateStaticLoader(http,'/assets/i18n','.json'),deps: [HttpClient]
})
],bootstrap: [AppComponent]
})
export class AppModule { }
2、注入TranslateService 服务
在需要用到的component里面注入TranslateService。
rush:js;">
import {TranslateService} from '@ngx-translate/core';
然后在构造函数中定义当前应用的默认语言。
rush:js;">
constructor(private translate: TranslateService) {
// this language will be used as a fallback when a translation isn't found in the current language
translate.setDefaultLang('en');
// use the brower's default lang,if the lang isn't available,it will use the 'en'
let broswerLang = translate.getbrowserLang();
translate.use(broswerLang.match(/en|cn/) ? broswerLang : 'en');
}
3、翻译文本书写规则
有两种方式可以加载我们翻译好的语言文本。
首先你可以把翻译好的语言文本放到一个json文件中,然后通过TranslateHttpLoader来引用这个json文件。
例如:en.json
rush:js;">
{
"HELLO": "hello {{value}}"
}
另外也可以通过setTranslation方法手动加载。
rush:js;">
translate.setTranslation('en',{
HELLO: 'hello {{value}}'
});
同时,这里的json结构是支持嵌套的。
rush:js;">
{
"HOME": {
"HELLO": "hello {{value}}"
}
}
以上结构,可以通过"HOME.HELLO"来引用HELLO的内容。
我们可以通过TranslateService,TranslatePipe 或者 TranslateDirective这三种方式来获取我们翻译的文本内容。
TranslateService:
{
console.log(res);
//=> 'hello world'
});
其中第二个参数{value: 'world'}是可选的。
TranslateService:
rush:xhtml;">
{{ 'HELLO' | translate:p
aram }}
param可以像如下方式在component里面定义。同样,这个参数也是可选的。
rush:js;">
p
aram = {value: 'world'};
TranslateDirective:
rush:xhtml;">
arams]="{value: 'world'}">
或者
rush:xhtml;">
arams]="{value: 'world'}">HELLO
5、使用HTML标签
允许在你的翻译文本中直接嵌入HTML标签。
rush:xhtml;">
{
"HELLO": "Welcome to my Angular application!
This is an amazing app which uses the latest technologies!
"
}
这时可以使用innerHTML 来进行渲染。
rush:xhtml;">
TranslateService API
公有属性(public properties):
rush:js;">
/**
* The default lang to fallback when translations are missing on the current lang
*/
defaultLang: string;
/**
* The lang currently used
* @type {string}
*/
currentLang: string;
/**
* an array of langs
* @type {Array}
*/
langs: string[];
/**
* a list of translations per lang
* @type {{}}
*/
translations: any;
公有方法(public methods):
rush:js;">
/**
* Sets the default language to use as a fallback
* @p
aram lang
*/
setDefaultLang(lang: string): void;
/**
* Gets the default language used
* @returns string
*/
getDefaultLang(): string;
/**
* Changes the lang currently used
* @p
aram lang
* @returns {Observable<*>}
*/
use(lang: string): Observable
;
/**
* Gets an object of translations for a given language with the current loader
* and passes it through the compiler
* @param lang
* @returns {Observable<*>}
*/
getTranslation(lang: string): Observable;
/**
* Manually sets an object of translations for a given language
* after passing it through the compiler
* @param lang
* @param translations
* @param shouldMerge
*/
setTranslation(lang: string,translations: Object,shouldMerge?: boolean): void;
/**
* Returns an array of currently available langs
* @returns {any}
*/
getLangs(): Array;
/**
* @param langs
* Add available langs
*/
addLangs(langs: Array): void;
/**
* Returns the parsed result of the translations
* @param translations
* @param key
* @param interpolateParams
* @returns {any}
*/
getParsedResult(translations: any,key: any,interpolateParams?: Object): any;
/**
* Gets the translated value of a key (or an array of keys)
* @param key
* @param interpolateParams
* @returns {any} the translated key,or an object of translated keys
*/
get(key: string | Array,interpolateParams?: Object): Observable;
/**
* Returns a stream of translated values of a key (or an array of keys) which updates
* whenever the language changes.
* @param key
* @param interpolateParams
* @returns {any} A stream of the translated key,or an object of translated keys
*/
stream(key: string | Array,interpolateParams?: Object): Observable;
/**
* Returns a translation instantly from the internal state of loaded translation.
* All rules regarding the current language,the preferred language of even fallback languages will be used except any promise handling.
* @param key
* @param interpolateParams
* @returns {string}
*/
instant(key: string | Array,interpolateParams?: Object): string | any;
/**
* Sets the translated value of a key,after compiling it
* @param key
* @param value
* @param lang
*/
set(key: string,value: string,lang?: string): void;
/**
* Allows to reload the lang file from the file
* @param lang
* @returns {Observable}
*/
reloadLang(lang: string): Observable;
/**
* Deletes inner translation
* @param lang
*/
resetLang(lang: string): void;
/**
* Returns the language code name from the browser,e.g. "de"
*
* @returns string
*/
getbrowserLang(): string;
/**
* Returns the culture language code name from the browser,e.g. "de-DE"
*
* @returns string
*/
getbrowserCultureLang(): string;
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。