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 相关文章推荐
javaScript checkbox 全选/反选及批量删除
Apr 28 Javascript
关于Jquery操作Cookie取值错误的解决方法
Aug 26 Javascript
iframe的父子窗口之间的对象相互调用基本用法
Sep 03 Javascript
javascript实现rgb颜色转换成16进制格式
Jul 10 Javascript
详解获取jq ul第一个li定位的四种解决方案
Nov 23 Javascript
jQuery实现联动下拉列表查询框
Jan 04 Javascript
详解用node搭建简单的静态资源管理器
Aug 09 Javascript
浅谈如何使用 webpack 优化资源
Oct 20 Javascript
Vue2.0中集成UEditor富文本编辑器的方法
Mar 03 Javascript
vue-列表下详情的展开与折叠案例
Jul 28 Javascript
vue修饰符.capture和.self的区别
Apr 22 Vue.js
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 引用是个坏习惯
2010/03/12 PHP
php中将网址转换为超链接的函数
2011/09/02 PHP
解析php中const与define的应用区别
2013/06/18 PHP
php+mysql数据库实现无限分类的方法
2014/12/12 PHP
php递归删除指定文件夹的方法小结
2015/04/20 PHP
javascript iframe中打开文件,并检测iframe存在否
2008/12/28 Javascript
dess中一个简单的多路委托的实现
2010/07/20 Javascript
读jQuery之二(两种扩展)
2011/06/11 Javascript
Jquery 复选框取值兼容FF和IE8(测试有效)
2013/10/29 Javascript
Javascript事件实例详解
2013/11/06 Javascript
客户端js判断文件类型和文件大小即限制上传大小
2013/11/20 Javascript
javascript实现行拖动的方法
2015/05/27 Javascript
详解jquery easyui之datagrid使用参考
2016/12/05 Javascript
详解AngularJS验证、过滤器、指令
2017/01/04 Javascript
label+input实现按钮开关切换效果的实例
2017/08/16 Javascript
angularJs-$http实现百度搜索时的动态下拉框示例
2018/02/27 Javascript
JS无限级导航菜单实现方法
2019/01/05 Javascript
angular6根据environments配置文件更改开发所需要的环境的方法
2019/03/06 Javascript
Node.js + express基本用法教程
2019/03/14 Javascript
图解NodeJS实现登录注册功能
2019/09/16 NodeJs
JavaScript编码小技巧分享
2020/09/17 Javascript
[08:07]DOTA2每周TOP10 精彩击杀集锦vol.8
2014/06/25 DOTA
[02:27]2018DOTA2亚洲邀请赛趣味视频之钓鱼大赛 谁是垂钓冠军?
2018/04/05 DOTA
[44:04]OG vs Mineski 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/18 DOTA
Python安装Imaging报错:The _imaging C module is not installed问题解决方法
2014/08/22 Python
Python 求数组局部最大值的实例
2019/11/26 Python
Farfetch香港官网:汇集全球时尚奢侈品购物平台
2017/11/26 全球购物
护士自荐信怎么写
2013/10/18 职场文书
互联网创业计划书的书写步骤
2014/01/28 职场文书
班班通项目实施方案
2014/02/25 职场文书
银行办公室岗位职责
2014/03/10 职场文书
青春飞扬演讲稿
2014/09/11 职场文书
2014年电话客服工作总结
2014/12/09 职场文书
母亲节寄语大全
2015/02/27 职场文书
2015年中学总务处工作总结
2015/07/22 职场文书
详解Go与PHP的语法对比
2021/05/29 PHP