Browse Source

i18n优化

noToken
安虹睿 1 year ago
parent
commit
aeca25d1be
  1. 40
      PC/InterFace.Dash/src/lang/index.js
  2. 4
      PC/InterFace.Dash/src/router/index.js

40
PC/InterFace.Dash/src/lang/index.js

@ -1,16 +1,19 @@
// lang/index.js
import Vue from "vue" import Vue from "vue"
import VueI18n from 'vue-i18n'
import ElementUI from "element-ui" import ElementUI from "element-ui"
import VueI18n from "vue-i18n" // element 多语言文件
// elment-ui import locale from 'element-ui/lib/locale'
import locale from "element-ui/lib/locale" import enLocale from 'element-ui/lib/locale/lang/en'
import zhLocale from "element-ui/lib/locale/lang/zh-CN" import zhLocale from 'element-ui/lib/locale/lang/zh-CN'
import enLocale from "element-ui/lib/locale/lang/en"
// 自己的多语言文件 // 自己的多语言文件
import zh from "./zh" import zh from "./zh"
import en from "./en" import en from "./en"
Vue.use(VueI18n) Vue.use(VueI18n)
Vue.use(ElementUI, { zhLocale });
// InitLanguage 将用户选择的语言存储到localStorage里
function InitLanguage() {
return (localStorage.getItem("browserLanguage") == null || localStorage.getItem("browserLanguage") == undefined) ? 'zh-CN' : localStorage.getItem("browserLanguage");
}
const messages = { const messages = {
"zh-CN": { "zh-CN": {
@ -21,30 +24,17 @@ const messages = {
...en, ...en,
...enLocale, ...enLocale,
} }
} };
const i18n = new VueI18n({ const i18n = new VueI18n({
legacy: false,
messages, messages,
globalInjection: true, // 全局生效$t
fallbackLocale: "zh-CN", // 匹配不到时默认的语言 fallbackLocale: "zh-CN", // 匹配不到时默认的语言
silentTranslationWarn: true, // 控制台的warning silentTranslationWarn: true, // 控制台的warning
locale: localStorage.getItem("browserLanguage") || "zh-CN", // set locale locale: InitLanguage(),
}) })
locale.use(ElementUI, { locale.i18n((key, value) => i18n.t(key, value))
i18n: (key, value) => i18n.t(key, value),
})
// ***
// 非 vue 文件中使用这个方法
const translate = (localeKey) => {
const locale = localStorage.getItem("language") || "zh-CN"
const hasKey = i18n.te(localeKey, locale) // 使用i18n的 te 方法来检查是否能够匹配到对应键值
const translatedStr = i18n.t(localeKey)
if (hasKey) {
return translatedStr
}
return localeKey
}
export { messages, translate }
export default i18n export default i18n

4
PC/InterFace.Dash/src/router/index.js

@ -1,6 +1,6 @@
import Vue from 'vue' import Vue from 'vue'
import Router from 'vue-router' import Router from 'vue-router'
import { translate as $t } from "@/lang" import i18n from "@/lang"
Vue.use(Router) Vue.use(Router)
@ -71,7 +71,7 @@ export let constantRoutes = [
name: 'Dashboard', name: 'Dashboard',
meta: { meta: {
keepAlive : true, keepAlive : true,
title: $t('common.home'), title: i18n.t('common.home'),
icon: 'svg_dashboard', icon: 'svg_dashboard',
outerFirst:true outerFirst:true
// affix: true // affix: true

Loading…
Cancel
Save