Angular2中如何使用ngx-translate进行国际化
时间:2019-03-30
本文章向大家介绍Angular2中如何使用ngx-translate进行国际化,主要包括Angular2中如何使用ngx-translate进行国际化使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
相较于AngularJS中的ng-translate, angular2也有适合自己的国际化模块,就是ngx-translate。
项目地址:https://github.com/ngx-translate/core
使用angular-cli初始化项目:
ng new my-project
使用npm安装ngx-translate模块
npm install --save @ngx-translate/core npm install --save @ngx-translate/http-loader
在项目的根模块app.module.ts中引入该模块
import { TranslateModule, TranslateLoader } from '@ngx-translate/core'; import { TranslateHttpLoader } from '@ngx-translate/http-loader'; export function HttpLoaderFactory(http:Http){ return new TranslateHttpLoader(http, './assets/i18n/', '.json'); } @NgModule({ declarations: [ AppComponent ], imports: [ ... TranslateModule.forRoot({ loader:{ provide:TranslateLoader, useFactory:HttpLoaderFactory, deps:[Http] } } ) ], providers: [], bootstrap: [AppComponent] })
在assets文件夹下新建i18n文件夹,并且新建两个语言的json文件。(比如zh-CN.json和en.json)
json文件是key-value形式的,key值代表要翻译的字符串,value值为特定语言的翻译结果,不用语言的文件一般key值是相同的,只是value值不同。
//zh-CN.json { "welcome":"欢迎使用本应用", "hello":"你好", "get-lang":"获取语言类型" } //en.json { "welcome":"welcome to this app", "hello":"Hola" }
然后在相应的组件中使用Translate服务
import { TranslateService } from '@ngx-translate/core' @Component({ ... }) export class AppComponent { constructor(private translate: TranslateService) { //添加语言支持 translate.addLangs(['zh-CN', 'en']); //设置默认语言,一般在无法匹配的时候使用 translate.setDefaultLang('zh-CN'); //获取当前浏览器环境的语言比如en、 zh let broswerLang = translate.getBrowserLang(); translate.use(broswerLang.match(/en|zh-CN/) ? broswerLang : 'zh-CN'); } changeLang(lang) { console.log(lang); this.translate.use(lang); } toggleLang() { console.log(this.translate.getBrowserLang()); //获取语言风格,相当于更详细的语言类型,比如zh-CN、zh-TW、en-US console.log(this.translate.getBrowserCultureLang()); } }
示例模板:
<div> <h2>{{ title | translate }}</h2> <label> {{ 'hello' | translate }} <select #langSelect (change)="changeLang(langSelect.value)"> <option *ngFor="let lang of translate.getLangs()" [value]="lang" [selected]="lang === translate.currentLang">{{ lang }}</option> </select> </label> </div> <button (click)="toggleLang()">{{'get-lang' | translate}}</button>
使用方式和angularjs中的ng-translate类似,使用translate管道。
效果:
源码地址:https://github.com/justforuse/angular2-demo/tree/master/angular-translate
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- MongoDB数据存储-深入了解
- Linux下通过受限bash创建指定权限的账号
- “AS3.0高级动画编程”学习:第四章 寻路(AStar/A星/A*)算法 (上)
- MongoDB副本(一主一备+仲裁)环境部署记录
- 根据前后的子串求中间串的函数
- Centos6下zookeeper集群部署记录
- 抓取百度指数引发的图像数字识别
- 真正将标注文字遮盖的方法
- “AS3.0高级动画编程”学习:第四章 寻路(AStar/A星/A*)算法 (中)
- li浮动时ul高度为0,解决ul自适应高度的几种方法
- 使用正则表达式求完整路径中的文件名
- “AS3.0高级动画编程”学习:第四章 寻路(AStar/A星/A*)算法 (下)
- Centos下SFTP双机高可用环境部署记录
- as3:Function以及call,apply
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 初识mybatis中的缓存
- 【卷积神经网络结构专题】ResNet及其变体的结构梳理、有效性分析
- Steganographer:能帮助在图片中隐藏数据的Python隐写工具
- 内网横向移动:Kerberos认证与(哈希)票据传递攻击
- 诺禾致源linux下数据下载
- 技巧 | OpenCV中如何绘制与填充多边形
- Swift guard
- PyTorch实现TPU版本CNN模型
- 使用NLP检测和对抗AI假新闻
- kallisto --genomebam报错解决(GTF文件的坑)
- linux查找文件
- TCP 协议面试灵魂 12 问,问到你怀疑人生!
- 方差分析简介(结合COVID-19案例)
- mysql计算两个时间字段的时间差
- 学生党学编程,有这个开源项目就够了!