我们会遇到国际化的问题,比如一个页面可以切换中英文,如果同样的代码写两份,势必会造成严重的冗余,所以我们可以利用国际化,优化代码的结构

如何使用

第一步安装依赖

npm install --save vue-i18n

基本使用

我们新建一个lang文件夹,内部存放国际化的字段名称

vue-i18n国际化_语言环境

 

 

然后在index.js中引入i18n并使用

 1 import Vue from 'vue'
 2 import VueI18n from 'vue-i18n'
 3 Vue.use(VueI18n)
 4 const i18n = new VueI18n({
 5     // 设置当前语言
 6     locale: 'zh',
 7     messages: {
 8         'en':{
 9             name:'name'
10         },
11         'zh':{
12             name:'名字'
13         }
14     }
15 })
16 export default i18n

 

在main.js文件中进行注册

 1 import Vue from 'vue'
 2 // 相对路径引入的App.vue文件
 3 import App from './App.vue'
 4 // 引入ui框架
 5 import elementUi from 'element-ui'
 6 //引入css
 7 import 'element-ui/lib/theme-chalk/index.css'
 8 //使用element-ui
 9 Vue.use(elementUi)
10 // 引入iview-ui框架
11 import iviewUi from "view-design"
12 //引入css
13 import 'view-design/dist/styles/iview.css'
14 //使用iview-ui
15 Vue.use(iviewUi)
16 //引入国际化
17 import i18n from "./lang/index.js"
18 console.log(i18n)
19 new Vue({
20     // 渲染节点
21     render: h => h(App),
22     i18n:i18n
23 }).$mount('#app')

此时我们就可以在任意的文件中使用国际化了

1 {{$t('name')}}

vue-i18n国际化_加载_02vue-i18n国际化_加载_03

 

 

 当把locale: 'zh',改为locale: 'en'时为英文

 

机理,就是我们页面显示的是i18n中messages中zh和en对应的字段名称,找的是相同key值,所以,如果我们要设置国际化,那么key值一定是相同的

 

如果这个文件中如果字段量特别大,需要拆分文件

此时我们可以在lang文件夹目录下继续新建zh 和en文件,分别用来存放中英文字段

vue-i18n国际化_语言环境_04

 

 

 1 import Vue from 'vue'
 2 import VueI18n from 'vue-i18n'
 3 import zh from "./zh.js"
 4 import en from "./en.js"
 5 Vue.use(VueI18n)
 6 const i18n = new VueI18n({
 7     // 设置当前语言
 8     locale: 'en',
 9     messages: {
10        en,
11        zh
12     }
13 })
14 export default i18n

 

如果切换中英文状态

我们可以通过修改this.$i18n.locale去进行切换

1  change(){
2           if(this.$i18n.locale=='zh'){
3               this.$i18n.locale='en'
4           }else{
5               this.$i18n.locale='zh'
6           }
7       }
8     }

 

中文

vue-i18n国际化_css_05

 

 英文

vue-i18n国际化_加载_06

 

 

此时的切换知识页面语言,和系统没有关系,如果刷新页面,还是会回到中文

 

设置并切换浏览器系统语言

我们现在写的当前的语言切换是默认的状态,初始化的时候一定加载的是默认的,比如默认的是中文,无论你后期改成什么状态,最后重新加载时一定是中文

此时我们需要设置系统的语言环境

 

我们使用localStorage去辅助我们完成国际化的语言环境设置

比如我们目目前只支持中英文

此时我们需要获取当前的语言状态

navigator.language能够获取当前浏览器的语言环境zh-CN是中文,en-US是英文

可以在lang文件中设置对应的语言环境

 1 import Vue from 'vue'
 2 import VueI18n from 'vue-i18n'
 3 import zh from "./zh.js"
 4 import en from "./en.js"
 5 Vue.use(VueI18n)
 6 // 设置对应的语言环境
 7     // 获取浏览器的语言环境
 8 const navLang=navigator.language
 9 let localLang = (navLang === 'zh-CN' ||navLang ===  'en-US' ) ? navLang:false
10 if(localLang=='zh-CN'){
11     localLang='zh'
12 }else if(localLang=='en-US'){
13     localLang='en'
14 }
15 // 获取localStorage的语言状态,如果没有设置默认的语言环境,如果浏览器默认也没有语言环境,就设置为中文
16 let lang=localStorage.getItem("lang")||localLang||'zh'
17   // localStorage存储最新的语言信息
18   localStorage.setItem("lang",lang)
19 console.log(navigator.language)
20 const i18n = new VueI18n({
21     // 设置当前语言
22     locale: localStorage.getItem('lang')||'zh',
23     messages: {
24        en,
25        zh
26     }
27 })
28 export default i18n

 

需要注意的是切换的时候也必选捎带存储一下localStorage的状态

1 change(){
2           if(this.$i18n.locale=='zh'){
3               this.$i18n.locale='en'
4           }else{
5               this.$i18n.locale='zh'
6           }
7           window.localStorage.setItem('lang',this.$i18n.local)
8       }

此时修改之后,即便是刷新页面,重新加载都能够持久之前的语言环境

vue-i18n国际化_css_07