您好,登錄后才能下訂單哦!
這篇文章主要講解了“vue element plus多語言切換怎么實現”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“vue element plus多語言切換怎么實現”吧!
解決一下問題:
如何實現多語言切換 ?
如何動態切換語言并更改elementUI語言 ?
更改完elementUI組件視圖不更新?
如何全局使用 $t 函數 ?
如何在js文件里使用vue-i18n ?
npm i vue-i18n --save
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文件中
import language, { getLanguage, $t } from './language' language(app)
<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>
// ----------------------- 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'
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 } } }
這時你會發現就算我們提交commit去更改elementUI的語言 頁面上也沒有發生變化,因為視圖組件并沒有更新,如何刷新組件使之重新加載呢?
// ----------------------- template----------------------------- <router-view v-if="isReloadRouter"/> // ----------------------- script----------------------------- const reload = () => { state.isReloadRouter = false nextTick(() => { state.isReloadRouter = true }) } provide("reload", reload) <-- 自行引入 provide nextTick ->
const handelLanguage = (name) => { lang.value = name store.commit(Types.SET_LANG, name) inject('reload')() }
import language, { getLanguage, $t } from './language' import '@/styles/elementDefault.scss' store.commit(Types.SET_LANG, getLanguage())
全局掛在 $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的方式
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多語言切換怎么實現”的內容了,經過本文的學習后,相信大家對vue element plus多語言切換怎么實現這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。