根据用户浏览器实现localLang

138 阅读1分钟
import Vue from 'vue'
import VueI18n from 'vue-i18n'

// 导入本地语言包
import mineZhCn from './lang/zh-CN'
import mineZhTw from './lang/zh-TW'
import mineEnUS from './lang/en-us'

// 导入组件库语言包
import zhCnLocale from 'iview/src/locale/lang/zh-CN'
import zhTwLocale from 'iview/src/locale/lang/zh-TW'
import enUsLocale from 'iview/src/locale/lang/en-US'

// 安装VueI18n
Vue.use(VueI18n)

// 根据用户浏览器设置vue语言
const navigatorLang = navigator.language
// 如果既不是简中又不是英语就返回false
const localLang = (navigatorLang === 'zn-CN' || navigatorLang === 'en-US')?navigatorLang : false
// 如果本地也没有储存语言类型就返回简中 
let lang = localLang || local('local') || 'zh-CN'

// 赋值给vue.config
vue.config.lang = lang

// 6.x写法配置vueI18n
Vue.locale = () => {}
const messages = {
    'zh-CN':Object.assign(zhCnLocale, mineZhCn)
    'zh-TW':Object.assign(zhTwLocale, mineZhTw)
    'zh-US':Object.assign(enUsLocale, mineEnUS)
}
const i18n = new VuewI18n({
    // 获取的浏览器的语言
    locale: lang,
    // 语言与语言包的键值对
    messages
})

// 默认导出
export default i18n

#main.js
// 注入入口Vue实例
import i18n from '@/locale'
new Vue({
   i18n,
})