溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vue?element?plus多語言切換怎么實現(xiàn)

發(fā)布時間:2021-12-09 17:11:26 來源:億速云 閱讀:686 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“vue element plus多語言切換怎么實現(xiàn)”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“vue element plus多語言切換怎么實現(xiàn)”吧!

解決一下問題:

  • 如何實現(xiàn)多語言切換 ?

  • 如何動態(tài)切換語言并更改elementUI語言 ?

  • 更改完elementUI組件視圖不更新?

  • 如何全局使用 $t 函數(shù) ?

  • 如何在js文件里使用vue-i18n ?

如何實現(xiàn)多語言切換 ?

1、安裝包vue-i18n

npm i vue-i18n --save

2、在src目錄下新建如圖:

vue?element?plus多語言切換怎么實現(xiàn)

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 函數(shù) 判斷當前l(fā)ocalStorage是否已有選擇過語言如果沒有則獲取當前瀏覽器的語言;
封裝 $t 函數(shù)并導(dǎo)出用在js文件中

3、 在main.js中

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

4、在vue文件中使用

<template>
    //1. 
	<div class="login clamp ta-c fs-28 fw-b m-b10">{{ $t('login.title') }}</div>
	//2.
	<el-input v-model="$t('login.title')"></el-input>
</template>

如何動態(tài)切換語言并更改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組件視圖不更新?

這時你會發(fā)現(xiàn)就算我們提交commit去更改elementUI的語言 頁面上也沒有發(fā)生變化,因為視圖組件并沒有更新,如何刷新組件使之重新加載呢?

1、 在router-view上控制視圖顯示/隱藏

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

2、 在切換語言時調(diào)用reload

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

3、需在main.js中調(diào)用一下commit,不然第一次進入elementUI 不會更改語言

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

如何全局使用 $t 函數(shù) ? 如何在js文件里使用vue-i18n ?

全局掛在 $t 函數(shù) ,在js文件里直接使用 $t 函數(shù)。

方法一:通過app.config.globalProperties掛在到全局

方法二: 通過provide、inject來實現(xiàn)

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, 需自行引入該函數(shù)

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')
      },

感謝各位的閱讀,以上就是“vue element plus多語言切換怎么實現(xiàn)”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對vue element plus多語言切換怎么實現(xiàn)這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI