vuei18n结合Elementui的配置

7次阅读

共计 1082 个字符,预计需要花费 3 分钟才能阅读完成。

使用方法:

在配合 Element-UI 一起使用时,会有 2 个问题:

(1)、页面刷新后,通过按钮切换的语言还原成了最初的语言,无法保存

(2)、框架内部自带的提示文字无法更改,比如像时间选择框内部中的提示文字

关于第一个问题,可以在初始化 VueI18n 实例时,通过 localStorage 来为 locale 对象赋值

在切换语言的时候可以缓存不同的语言选项,并且可以长期保存,不会因为刷新网页而改变 locale 的属性值

const i18n = new VueI18n({
locale: localStorage.getItem(‘locale’) || ‘zh’,
messages
})

关于第二个问题,更改 Element 组件内部语言,这里还涉及到 手动处理 vue-i18n@6.x 兼容性问题。http://element-cn.eleme.io/#/… 官网已经做了详细介绍,这里依葫芦画瓢跟着实现一下

i18n.js

import Vue from ‘vue’
import VueI18n from ‘vue-i18n’
import locale from ‘element-ui/lib/locale’;
import zh from ‘./langs/zh’
import en from ‘./langs/en’
import enLocale from ‘element-ui/lib/locale/lang/en’
import zhLocale from ‘element-ui/lib/locale/lang/zh-CN’
Vue.use(VueI18n)
const messages = {
en: Object.assign(en, enLocale),
zh: Object.assign(zh, zhLocale)
}
console.log(messages.zh)
const i18n = new VueI18n({
locale: localStorage.getItem(‘locale’) || ‘zh’,
messages
})
locale.i18n((key, value) => i18n.t(key, value)) // 为了实现 element 插件的多语言切换
export default i18n

按照如上把国际化文件都整合到一起,避免 main.js 中大段引入相关代码。main.js 中与 i18n 相关的就只剩两行代码

main.js

import i18n from ‘./i18n/i18n’ // 1 行
window.app = new Vue({
el: ‘#app’,
router,
store,
i18n, // 2 行
components: {App},
template: ‘<App/>’
})

正文完
 0