热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

详解vue element plus多语言切换

这篇文章主要为大家介绍了vue element plus多语言切换,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,

前言

最近接手一个项目,该项目多国家使用,需要支持多语言的切换,在此记录。

解决一下问题:

  • 如何实现多语言切换 ?
  • 如何动态切换语言并更改elementUI语言 ?
  • 更改完elementUI组件视图不更新?
  • 如何全局使用 $t 函数 ?
  • 如何在js文件里使用vue-i18n ?

如何实现多语言切换 ?

1、安装包vue-i18n

npm i vue-i18n --save

2、在src目录下新建如图:

在这里插入图片描述

en.js

const EN = {
  login: {
    title: "User Login"
  },
}
export default  EN

pl-pl.js

const PL_PL = {
  login: {
    title: "Użytkownik jest zalogowany"
  },
}
export default  PL_PL

zh-cn.js

const ZH_CN = {
  login: {
    title: "用户登录"
  },
}
export default  ZH_CN

index.js

import { createI18n } from "vue-i18n/index"
import "dayjs/locale/zh-cn"
import zh from "./zh-cn"
import en from "./en"
import pl from "./pl-pl"
const messages = {
  "zh-cn": zh,
  "en": en,
  "pl": pl
}
// Gets the current locale
export function getLanguage() {
  // Use the language of choice 
  const chooselang = localStorage.getItem("locale")
  if (chooselang) return chooselang
  // if not shoose language
  const lang = (navigator.language || navigator.browserLanguage).toLowerCase()
  const locales = Object.keys(messages)
  return locales.includes(lang) ? lang : "zh-cn"
}
const i18n = createI18n({
  locale: getLanguage(),
  fallbackLocale: "en",
  global: true,
  messages
})
export function $t(args) {
  return i18n.global.tc(args)
}
console.log($t("login.title"))
export default (app) => {
  app.use(i18n)
}

说明

getLanguage 函数 判断当前localStorage是否已有选择过语言如果没有则获取当前浏览器的语言;
封装 $t 函数并导出用在js文件中

3、 在main.js中

import language, { getLanguage, $t } from "./language"
language(app)

4、在vue文件中使用


如何动态切换语言并更改elementUI语言 ?

1、利用vuex,在mutations中写一个方法更改element语言

// ----------------------- state -----------------------------
import { getLanguage } from "@/language"
const state = {
  lang: getLanguage()
}
export default state
// ----------------------- mutations-----------------------------
import * as Types from "./types"
import locale from "element-plus/lib/locale"
import localeZH from "element-plus/lib/locale/lang/zh-cn"
import localeEN from "element-plus/lib/locale/lang/en"
import localePL from "element-plus/lib/locale/lang/pl"
const element = {
  "zh-cn": localeZH,
  "en": localeEN,
  "pl": localePL
}
const mutatiOns= {
  // 切换语言
  [Types.SET_LANG](state, lang) {
    state.lang = lang
    localStorage.setItem("locale", lang)
    locale.use(element[lang])
  }
}
export default mutations
// ----------------------- types-----------------------------
export const SET_LANG = "SET_LANG"

2、使用

import * as Types from "@/store/types"
import { useI18n } from "vue-i18n";
export default {
  setup(props,ctx) {
    const { locale: lang } = useI18n({ useScope: "global" })
    let store = useStore()
    const handelLanguage = (name) => {
      lang.value = name
      store.commit(Types.SET_LANG, name)
    }
    return {
      handelLanguage
    }
  }
}

更改完elementUI组件视图不更新?

这时你会发现就算我们提交commit去更改elementUI的语言 页面上也没有发生变化,因为视图组件并没有更新,如何刷新组件使之重新加载呢?

1、 在router-view上控制视图显示/隐藏

// ----------------------- template-----------------------------

// ----------------------- script-----------------------------
const reload = () => {
	 state.isReloadRouter = false
     nextTick(() => {
       state.isReloadRouter = true
     })
}
provide("reload", reload)
<-- 自行引入 provide nextTick ->

2、 在切换语言时调用reload

 const handelLanguage = (name) => {
      lang.value = name
      store.commit(Types.SET_LANG, name)
      inject("reload")()
    }

3、需在main.js中调用一下commit,不然第一次进入elementUI 不会更改语言

import language, { getLanguage, $t } from "./language"
import "@/styles/elementDefault.scss"
store.commit(Types.SET_LANG, getLanguage())

如何全局使用 $t 函数 ? 如何在js文件里使用vue-i18n ?

全局挂在 $t 函数 ,在js文件里直接使用 $t 函数。

方法一:通过app.config.globalProperties挂在到全局

方法二: 通过provide、inject来实现

import language, { getLanguage, $t } from "./language"
const app = createApp(App);
// ----------------------- app.config.globalProperties -----------------------------
app.config.globalProperties.$t = $t
// 使用
import { getCurrentInstance } from "vue"
const { proxy } = getCurrentInstance()
proxy.$t()
// ----------------------- provide、inject -----------------------------
// main.js中
app.provide("$t", $t)
// 使用
const $t = inject("$t")
ElMessage.warning({
  message: $t("login.warnMessage"),
   type: "warning"
 });
vue3不推荐在原型链上挂载一些东西,而更推荐使用provide、inject,所以最好使用通过依赖和注入provide和inject的方式

在router.js中不能直接使用$t, 需自行引入该函数

import { $t } from "@/language"
{
        path: "/mainManage/device",
        name: "device",
        hidden: false,
        meta: { icon: "circle", title: $t("router.device") },
        component: () =>
          import(/* webpackChunkName: "device" */ "@/views/mainManage/device")
      },

目前有一问题:因为我菜单展示的字段取的是路由信息里的title,router.js只在项目第一次进入的时候调用,当切换语言的时候菜单字段不会动态切换,只有刷新浏览器才会改变,如有解决方法希望留言告知!!!

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注编程笔记的更多内容!


推荐阅读
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • Webpack5内置处理图片资源的配置方法
    本文介绍了在Webpack5中处理图片资源的配置方法。在Webpack4中,我们需要使用file-loader和url-loader来处理图片资源,但是在Webpack5中,这两个Loader的功能已经被内置到Webpack中,我们只需要简单配置即可实现图片资源的处理。本文还介绍了一些常用的配置方法,如匹配不同类型的图片文件、设置输出路径等。通过本文的学习,读者可以快速掌握Webpack5处理图片资源的方法。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • vue使用
    关键词: ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • 知识图谱——机器大脑中的知识库
    本文介绍了知识图谱在机器大脑中的应用,以及搜索引擎在知识图谱方面的发展。以谷歌知识图谱为例,说明了知识图谱的智能化特点。通过搜索引擎用户可以获取更加智能化的答案,如搜索关键词"Marie Curie",会得到居里夫人的详细信息以及与之相关的历史人物。知识图谱的出现引起了搜索引擎行业的变革,不仅美国的微软必应,中国的百度、搜狗等搜索引擎公司也纷纷推出了自己的知识图谱。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 怀疑是每次都在新建文件,具体代码如下 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
  • Java学习笔记之面向对象编程(OOP)
    本文介绍了Java学习笔记中的面向对象编程(OOP)内容,包括OOP的三大特性(封装、继承、多态)和五大原则(单一职责原则、开放封闭原则、里式替换原则、依赖倒置原则)。通过学习OOP,可以提高代码复用性、拓展性和安全性。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
author-avatar
静静静静静静妹儿_
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有