vue-i18n结合Element-ui的配置方法


Posted in Javascript onMay 20, 2019

使用方法:

在配合 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: '' })

---------------------------源码如下--------------------------------------

// 工程本地 国际化
import locale_zh_CN from './lang/zh-CN'
import locale_zh_TW from './lang/zh-TW'
import locale_en_US from './lang/en-US'
import locale_ko_KR from './lang/ko-KR'
// ElementUI 国际化
import element_locale from 'element-ui/lib/locale'
import element_zh_CN from 'element-ui/lib/locale/lang/zh-CN'
import element_zh_TW from 'element-ui/lib/locale/lang/zh-TW'
import element_en_US from 'element-ui/lib/locale/lang/en'
import element_ko_KR from 'element-ui/lib/locale/lang/ko'
import Vue from 'vue'
import VueI18n from 'vue-i18n'
Vue.use(VueI18n)
// 将各自的 国际化文件合并 抛出 (后期公共组件等插件的 国际化文件也需要考虑)
const messages = {
zh_CN: Object.assign(locale_zh_CN, element_zh_CN),
zh_TW: Object.assign(locale_zh_TW, element_zh_TW),
en_US: Object.assign(locale_en_US, element_en_US),
ko_KR: Object.assign(locale_ko_KR, element_ko_KR)
}
// i18n插件默认给中文
const i18n = new VueI18n({
locale: window.localStorage.getItem('WEBFRONT_LANG') || 'zh_CN',
messages
})
// 为了实现element插件的多语言切换
element_locale.i18n((key, value) => i18n.t(key, value))
export default i18n

总结

以上所述是小编给大家介绍的vue-i18n结合Element-ui的配置方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
setInterval 和 setTimeout会产生内存溢出
Feb 15 Javascript
jQuery把表单元素变为json对象
Nov 06 Javascript
jquery实现input输入框实时输入触发事件代码
Jan 28 Javascript
JavaScript框架是什么?怎样才能叫做框架?
Jul 01 Javascript
js+div实现文字滚动和图片切换效果代码
Aug 27 Javascript
jQuery 遍历map()方法详解
Nov 04 Javascript
vue.js绑定class和style样式(6)
Dec 09 Javascript
JavaScript求一组数的最小公倍数和最大公约数常用算法详解【面向对象,回归迭代和循环】
May 07 Javascript
解决element UI 自定义传参的问题
Aug 22 Javascript
JS+CSS3实现的简易钟表效果示例
Apr 13 Javascript
用云开发Cloudbase实现小程序多图片内容安全监测的代码详解
Jun 07 Javascript
Vant 在vue-cli 4.x中按需加载操作
Nov 05 Javascript
JS实现选项卡效果的代码实例
May 20 #Javascript
微信打开网址添加在浏览器中打开提示的办法
May 20 #Javascript
浅谈Vuex注入Vue生命周期的过程
May 20 #Javascript
微信小程序图表插件wx-charts用法实例详解
May 20 #Javascript
Nuxt项目支持eslint+pritter+typescript的实现
May 20 #Javascript
vue3.0 搭建项目总结(详细步骤)
May 20 #Javascript
vue-cli webpack配置文件分析
May 20 #Javascript
You might like
Yii框架在页面输出执行sql语句以方便调试的实现方法
2014/12/24 PHP
Yii 2.0自带的验证码使用经验分享
2017/06/19 PHP
jQuery EasyUI API 中文文档 - PropertyGrid属性表格
2011/11/18 Javascript
浅谈Javascript事件模拟
2012/06/27 Javascript
js 获取页面高度和宽度兼容 ie firefox chrome等
2014/05/14 Javascript
nodejs npm包管理的配置方法及常用命令介绍
2014/06/05 NodeJs
JavaScript中的数据类型转换方法小结
2015/10/26 Javascript
详解JavaScript对象类型
2016/06/16 Javascript
Angularjs 制作购物车功能实例代码
2016/09/14 Javascript
JS中利用swiper实现3d翻转幻灯片实例代码
2017/08/25 Javascript
详解关于React-Router4.0跳转不置顶解决方案
2019/05/10 Javascript
vue.js+ElementUI实现进度条提示密码强度效果
2020/01/18 Javascript
JS实现页面侧边栏效果探究
2021/01/08 Javascript
Python标准库os.path包、glob包使用实例
2014/11/25 Python
深入理解Python装饰器
2016/07/27 Python
python用Pygal如何生成漂亮的SVG图像详解
2017/02/10 Python
Python json 错误xx is not JSON serializable解决办法
2017/03/15 Python
在cmder下安装ipython以及环境的搭建
2018/10/19 Python
Python3 单行多行万能正则匹配方法
2019/01/07 Python
使用Pandas对数据进行筛选和排序的实现
2019/07/29 Python
python yield关键词案例测试
2019/10/15 Python
Python 使用xlwt模块将多行多列数据循环写入excel文档的操作
2020/11/10 Python
英国安全产品购物网站:The Safe Shop
2017/03/20 全球购物
全球地下的服装和态度:Slam Jam
2018/02/04 全球购物
匡威意大利官方商店 :Converse意大利
2018/11/27 全球购物
正宗的澳大利亚Ugg靴子零售商:UGG Express
2020/04/19 全球购物
什么是托管函数?托管函数有什么用?
2014/06/15 面试题
UNIX操作系统结构由哪几部分组成
2016/02/17 面试题
经济信息管理专业大学生求职信
2013/09/27 职场文书
关于读书的演讲稿1000字
2014/08/27 职场文书
研究生导师评语
2014/12/31 职场文书
《我的伯父鲁迅先生》教学反思
2016/02/16 职场文书
Pytest之测试命名规则的使用
2021/04/16 Python
React 高阶组件HOC用法归纳
2021/06/13 Javascript
SQLServer中JSON文档型数据的查询问题解决
2021/06/27 SQL Server
纯CSS如何禁止用户复制网页的内容
2021/11/01 HTML / CSS