IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue-element-admin添加国际化(切换中英文) -> 正文阅读

[JavaScript知识库]vue-element-admin添加国际化(切换中英文)

? ? ? ?后台系统中,常常遇到实现中英文切换的功能,vue-element-admin官方文档中也介绍了如何添加国际化,今天来详细说明:

? ? ? ? Ⅰ?实现效果:

? ? ? ? ? ? ? ?中文:????????????????

? ? ? ? ? ? ? ? ?英文:

下面直接上步骤:

? ? ? ? 一、下载安装

? ? ? ??????????npm install vue-i18n@8.24.5 -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 i18n

? ? ? ? ? en.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,

? ? ? ? 三、页面应用

? ? ? ? ? ? ? ? ① 在顶部加入语音选择下拉框,(实际添加位置以自己项目所需的位置即可)

? ? ? ? ? ? ? ? ?语言选择下拉框组件:

?????????????????代码:

<template>
	<el-dropdown trigger="click" class="international" @command="handleSetLanguage">
		<div>
			请选择语言
		</div>
		<el-dropdown-menu slot="dropdown">
			<el-dropdown-item :disabled="language==='zh'" command="zh">中文</el-dropdown-item>
			<el-dropdown-item :disabled="language==='en'" command="en">English</el-dropdown-item>
		</el-dropdown-menu>
	</el-dropdown>
</template>

<script>
	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')
			}
		}
	}
</script>

<style>
</style>

? ? ? ? ? ? ? ? ?② 在页面通过$t('')来渲染,如下图:

? ? ? ? ?四、当然一个项目完全转换还需要转换侧边栏,面包屑等,下面来展示侧边栏如何转换:

???????????????找到侧边栏页面,添加页面内容:? ? ? ? ?

? ? ? 注:① 一定要在methods中声明该方法!

? ? ? ? ? ? ?② 英文的翻译名称与路由中的meta中title一致!

? ? ? ? 最后如果通过循环来展示数据的,在js?中写到computed方法中即可实现,例如:

?

? ? ? ? 也同样可以实现!另外想要获取当前的语言可以通过this.$store.getters.language来获取,

?

?

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-10-31 11:46:33  更:2022-10-31 11:51:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/17 19:03:14-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码