1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
|
import Vue from 'vue' import VueI18n from 'vue-i18n' import VueCookie from 'vue-cookie' import elementEnLocale from 'element-ui/lib/locale/lang/en' import elementZhLocale from 'element-ui/lib/locale/lang/zh-CN' import elementEsLocale from 'element-ui/lib/locale/lang/es' import enLocale from './en.json' import zhLocale from './zh.json' import esLocale from './es.json'
Vue.use(VueI18n)
const messages = { en: { ...enLocale, ...elementEnLocale }, zh: { ...zhLocale, ...elementZhLocale }, es: { ...esLocale, ...elementEsLocale } }
export function getLanguage() { const chooseLanguage = VueCookie.get('Language') if (chooseLanguage) return chooseLanguage
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({ locale: getLanguage(), fallbackLocale: 'zh', silentTranslationWarn: true, messages })
export default i18n
|