这个功能是根据浏览器语言实现自动切换翻译语言,需要替换项目文件中所有展示的中文字句
1.先在项目中安装vue-i18n的依赖
npm install vue-i18n --save
在src文件夹下创建lang文件夹,如下图所示:
1.lang文件夹下的index.js文件
import Vue from 'vue'
import VueI18n from 'vue-i18n'
import Cookies from 'js-cookie'
import elementEnLocale from 'element-ui/lib/locale/lang/en' // element-ui lang
import elementEsLocale from 'element-ui/lib/locale/lang/es' // element-ui lang
import elementZhLocale from 'element-ui/lib/locale/lang/zh-CN'// element-ui lang
import enLocale from './en'
import zhLocale from './zh'
import esLocale from './es'
Vue.use(VueI18n)
const messages = {
en: { //英文语言包
...enLocale,
...elementEnLocale
},
zh: { //中文语言包
...zhLocale,
...elementZhLocale
},
es: { //西班牙语语言包
...esLocale,
...elementEsLocale
},
}
const model = [
'Base'
]
model.forEach((key) => {
// eslint-disable-next-line
const value = require(`./i18n/${key}`).default
Object.keys(value).forEach((k) => {
const { en, zh, es } = value[k]
messages.en[key] = messages.en[key] || {}
messages.zh[key] = messages.zh[key] || {}
messages.es[key] = messages.es[key] || {}
messages.en[key][k] = en
messages.zh[key][k] = zh
messages.es[key][k] = es
})
})
export function getLanguage() {
const chooseLanguage = Cookies.get('language')
if (chooseLanguage) return chooseLanguage
// if has not choose language
const language = (navigator.language || navigator.browserLanguage).toLowerCase()
const locales = Object.keys(messages)
for (const locale of locales) {
if (language.indexOf(locale) > -1) {
return locale
}
}
return 'zh'
}
const i18n = new VueI18n({
// set locale
// options: en | zh | es
locale: getLanguage(),
// set locale messages
messages,
silentTranslationWarn: true
})
export default i18n
2.在lang文件夹下的i18n文件夹中的index.js文件(主要是做重复公共类定义与翻译)
import zhLocale from 'element-ui/lib/locale/lang/zh-CN'
import enLocale from 'element-ui/lib/locale/lang/en'
import esLocale from 'element-ui/lib/locale/lang/es'
const lang = {
en: {
...enLocale,
},
zh: {
...zhLocale,
},
es: {
...esLocale,
},
}
const model = [
'Base',
]
model.forEach((key) => {
// eslint-disable-next-line
const value = require(`./${key}`).default
Object.keys(value).forEach((k) => {
const { en, zh, es } = value[k]
lang.en[key] = lang.en[key] || {}
lang.zh[key] = lang.zh[key] || {}
lang.es[key] = lang.es[key] || {}
lang.en[key][k] = en
lang.zh[key][k] = zh
lang.es[key][k] = es
})
})
export default lang
3.Base.js文件
export default {
add: {
zh: '新增',
en: 'New',
es: 'Nuevo'
},
...//自定义
}
4.zh.js文件(其余语言文件定义变量语法格式同下,翻译同一处必须为同一变量名)
export default {
index: {
dashboard: '首页',//en.js文件'Home page' es.js文件'En la primera página'
profile: '个人中心',
order:'序号',
name:'名称',
input:'请输入'
},
...//自定义
}
main.js文件
import i18n from './lang' // internationalization
Vue.use(Element, {
i18n: (key, value) => i18n.t(key, value),
size: Cookies.get('size') || 'medium' // set element-ui default size
})
export default new Vue({
el: '#app',
router,
store,
i18n,
render: h => h(App)
})
1.使用在html标签字
<div>{{$t('Base.add')}}div>
2.使用在element表格
<el-table-column prop="order" :label="$t('index.order')">el-table-column>
3.使用在element表单及校验
<el-form-item :label="$t('index.name')+`:`" prop="name">
<el-input v-model="form.name" :placeholder="$t('index.input')">el-input>
el-form-item>
rules: {
name: [{ required: true, message: this.$t('index.input'), trigger: "blur" }],
},
4.使用在export的js文件
import vm from "@/main"
export const statusList = [
{
label: vm.$t('Base.WaitActivate'), //等待执行
value: "0",
},
{
label: vm.$t('Base.activated'), //已执行
value: "1",
},
]