vue |
您所在的位置:网站首页 › 金属火灾是哪类 › vue |
后台系统中,常常遇到实现中英文切换的功能,vue-element-admin官方文档中也介绍了如何添加国际化,今天来详细说明: Ⅰ 实现效果: 中文: 英文: 下面直接上步骤: 一、下载安装 npm install [email protected] -S 在此要注意版本号 二、新增文件 ① 在src下新建文件夹lang,在文件夹lang中分别新建不同语音的js文件,具体如下图:
其中index.js: ` 代码如下: // 进行多语言支持配置 import Vue from 'vue' // 引入Vue import VueI18n from 'vue-i18n' // 引入国际化的插件包 import Cookies from 'js-cookie' // 引入 Cookies 保存当前默认语言选项 import elementEnLocale from 'element-ui/lib/locale/lang/en' // element-ui 英文包 import elementZhLocale from 'element-ui/lib/locale/lang/zh-CN'// element-ui 中文包 // 自定义的中英文配置 import enLocale from './en' import zhLocale from './zh' Vue.use(VueI18n); // 全局注册国际化包 // 创建国际化插件的实例 const i18n = new VueI18n({ // 指定语言类型 zh表示中文 en表示英文 set locale 设置默认初始化的语言 i18n locale: Cookies.get('language') || 'zh', // 将将elementUI语言包 和自定义语言包 加入到插件语言数据里 set locale messages messages: { // 英文环境下的语言数据 en: { ...enLocale, ...elementEnLocale }, // 中文环境下的语言数据 zh: { ...zhLocale, ...elementZhLocale } } }); export default i18nen.js和zh.js文件中分别放入对应的不同语言,如下图: ② 在utils文件中新建i18.js文件夹 代码: // 翻译router.meta。标题,用于面包屑侧边栏tagsview export function generateTitle(title) { const hasKey = this.$te('route.' + title) if (hasKey) { // $t :this method from vue-i18n, inject in @/lang/index.js const translatedTitle = this.$t('route.' + title) return translatedTitle } return title }三、配置 ① main.js文件中添加图中红框中内容
部分代码: import i18n from './lang' Vue.use(ElementUI, { i18n: (key, value) => i18n.t(key, value) })② 配置store文件夹 modules文件夹下app.js文件添加下图红框内容: 单独代码: language: Cookies.get('language') || 'zh' // ...其他配置项省略... SET_LANGUAGE: (state, language) => { state.language = language Cookies.set('language', language) } // ...其他配置项省略... setLanguage({ commit }, language) { commit('SET_LANGUAGE', language) },getters.js文件夹添下图内容: 部分代码: language: state => state.app.language, size: state => state.app.size,三、页面应用 ① 在顶部加入语音选择下拉框,(实际添加位置以自己项目所需的位置即可) 语言选择下拉框组件: 代码: 请选择语言 中文 English export default { name: "LangSelect", computed: { language() { return this.$store.getters.language } }, data(){ return{ } }, created() { }, watch:{ }, methods: { handleSetLanguage(lang) { this.$i18n.locale = lang; this.$store.dispatch('app/setLanguage', lang) this.$message.success('switch language success') } } }② 在页面通过$t('')来渲染,如下图: 四、当然一个项目完全转换还需要转换侧边栏,面包屑等,下面来展示侧边栏如何转换: 找到侧边栏页面,添加页面内容: 注:① 一定要在methods中声明该方法! ② 英文的翻译名称与路由中的meta中title一致! 最后如果通过循环来展示数据的,在js 中写到computed方法中即可实现,例如:
也同样可以实现!另外想要获取当前的语言可以通过this.$store.getters.language来获取,
|
今日新闻 |
点击排行 |
|
推荐新闻 |
图片新闻 |
|
专题文章 |
CopyRight 2018-2019 实验室设备网 版权所有 win10的实时保护怎么永久关闭 |