Vue3 + Element Plus + i18n 國際化

1 前言

本篇旨在 Vue3 + Element Plus 國際化配置,支持多語言切換

2 Vue3 國際化

2.1 安裝 vue-i18n

npm i vue-i18n

2.2 新建 locales 文件夾

簡體中文英文為例

  • 在 src 下新建 locales 文件夾
  • 在 locales 文件夾下新建 zh-cn.ts
export default {
  buttons: {
    login: '登錄'
  },
  menus: {
    home: '首頁'
  }
}
  • 在 locales 文件夾下新建 en.ts
export default {
  buttons: {
    login: 'Login'
  },
  menus: {
    home: 'Home'
  }
}
  • 在 locales 文件夾下新建 index.ts
import { createI18n } from 'vue-i18n'
import zhCn from './zh-cn'
import en from './en'

// 創(chuàng)建 i18n
const i18n = createI18n({
  legacy: false,
  globalInjection: true, // 全局模式,可以直接使用 $t
  locale: localStorage.getItem('lang') || 'zhCn',
  messages: {
    zhCn,
    en
  }
})

export default i18n

2.3 注冊 i18n

在 main.ts 文件下注冊 i18n

import { createApp } from 'vue'
import App from './App.vue'
import i18n from './locales'

const app = createApp(App)

app.use(i18n)

app.mount('#app')

2.4 使用方法

2.4.1 在 template 中的使用

{{ $t('menus.home') }}

2.4.2 在 ts 中的使用

import i18n from './locales'

console.log(i18n.global.t('menus.home'))

3 Element Plus 國際化

Element Plus 官方提供了一個 Vue 組件 ConfigProvider 用于全局配置國際化的設(shè)置
el-config-provider 由 Element Plus 按需引入 - 自動導(dǎo)入
el-config-provider 手動導(dǎo)入:import { ElConfigProvider } from 'element-plus'

<template>
  <el-config-provider :locale="useAppStoreHook().locale === 'zhCn' ? zhCn : en">
    <app />
  </el-config-provider>
</template>

<script lang="ts" setup>
import zhCn from 'element-plus/lib/locale/lang/zh-cn'
import en from 'element-plus/lib/locale/lang/en'
import { useAppStoreHook } from '@/store/modules/app' //store存放語言配置
</script>

4 語言切換

切換語言時,修改 store 、 localstorage 和 i18n 中的語言配置

// store/modules/app

import { defineStore } from 'pinia'
import { store } from '@/store'
import i18n from '@/locales'

const useAppStore = defineStore('app', {
  state: () => {
    return {
      locale: localStorage.getItem('lang') || 'zhCn'
    }
  },
  actions: {
    SET_LOCALE(locale: string) { //語言切換
      this.locale = locale
      storageLocal.setItem('lang', locale)
      i18n.global.locale.value = locale
    }
  }
})

export function useAppStoreHook() {
  return useAppStore(store)
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容