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 相关文章推荐
自己开发Dojo的建议框架
Sep 24 Javascript
js图片向右一张张滚动效果实例代码
Nov 23 Javascript
Javascript学习笔记之 对象篇(四) : for in 循环
Jun 24 Javascript
Javascript保存网页为图片借助于html2canvas库实现
Sep 05 Javascript
js链表操作(实例讲解)
Aug 29 Javascript
JS实现点击下拉菜单把选择的内容同步到input输入框内的实例
Jan 23 Javascript
vue监听键盘事件的快捷方法【推荐】
Jul 11 Javascript
ES6的解构赋值实例详解
May 06 Javascript
JS实现数组删除指定元素功能示例
Jun 05 Javascript
解决vue单页面修改样式无法覆盖问题
Aug 05 Javascript
JS常用正则表达式超全集(密码强度校验,金额校验,IE版本,IPv4,IPv6校验)
Feb 03 Javascript
vue实现下拉菜单树
Oct 22 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
php 清除网页病毒的方法
2008/12/05 PHP
PHP执行zip与rar解压缩方法实现代码
2010/12/05 PHP
深入PHP autoload机制的详解
2013/06/09 PHP
php截取字符串函数分享
2015/02/02 PHP
PHP面向对象编程之深入理解方法重载与方法覆盖(多态)
2015/12/24 PHP
yii权限控制的方法(三种方法)
2015/12/28 PHP
利用Laravel事件系统如何实现登录日志的记录详解
2017/05/20 PHP
一文看懂PHP进程管理器php-fpm
2020/06/01 PHP
Javascript miscellanea -display data real time, using window.status
2007/01/09 Javascript
JavaScript入门教程(10) 认识其他对象
2009/01/31 Javascript
用js做一个小游戏平台 (一)
2009/12/29 Javascript
一个实用的图片切换支持点击切换和自动轮播
2014/09/09 Javascript
jQuery验证插件 Validate详解
2014/11/20 Javascript
javascript实时获取鼠标坐标值并显示的方法
2015/04/30 Javascript
jQuery 3 中的新增功能汇总介绍
2016/06/12 Javascript
Angualrjs 表单验证的两种方式(失去焦点验证和点击提交验证)
2017/05/09 Javascript
深入浅析JS中的严格模式
2018/06/04 Javascript
js+canvas实现转盘效果(两个版本)
2020/09/13 Javascript
如何手写简易的 Vue Router
2020/10/10 Javascript
在Python中操作日期和时间之gmtime()方法的使用
2015/05/22 Python
python实现在控制台输入密码不显示的方法
2015/07/02 Python
使用Python实现BT种子和磁力链接的相互转换
2015/11/09 Python
Python爬虫爬取一个网页上的图片地址实例代码
2018/01/16 Python
python中的字符串内部换行方法
2018/07/19 Python
在pycharm中创建django项目的示例代码
2020/05/28 Python
Python StringIO及BytesIO包使用方法解析
2020/06/15 Python
美国最大网上鞋店:Zappos
2016/07/25 全球购物
Reebonz中国官网:新加坡奢侈品购物网站
2017/03/17 全球购物
开学典礼主持词
2014/03/19 职场文书
幼儿园区域活动总结
2014/05/08 职场文书
商业计算机应用专业自荐书
2014/06/09 职场文书
2015年教务工作总结
2015/05/23 职场文书
搭讪开场白台词大全
2015/05/28 职场文书
养成教育主题班会
2015/08/13 职场文书
心得体会格式及范文
2016/01/25 职场文书
python图片灰度化处理的几种方法
2021/06/23 Python