多国语言组件vue-i18n / 网络研习社#75

in hive-180932 •  4 years ago 

language.jpg

vue-i18n是个非常实用的多国语言组件!当你的网站要配置多种语言的界面时,用它是首选。用起来倒也容易,翻下手册,看几个实用的案例,就基本上八九不离十啰。可以说,上手的成本挺小的。

参考手册

npm install vue-i18n --save

//main.js
import VueI18n from 'vue-i18n'

Vue.use(VueI18n)
const DEFAULT_LANG = navigator.language
// console.log(888, 'DEFAULT_LANG', DEFAULT_LANG)  //888 "DEFAULT_LANG" "zh-CN"  "DEFAULT_LANG" "en"
const LOCALE_KEY = 'localeLanguage'
const i18n = new VueI18n({
  locale:'zh-CN',
  messages: {
    'zh-CN': require('./assets/lang/zh_CN'),
    'en': require('./assets/lang/EN')
  },
  fallbackLocale: 'zh-CN'
})
const setup = lang => {
  if (lang === undefined){
    lang = window.localStorage.getItem(LOCALE_KEY)
    if (i18n.messages[lang] === undefined){
      lang = DEFAULT_LANG
    }
  }
  window.localStorage.setItem(LOCALE_KEY, lang)
  Object.keys(i18n.messages).forEach(lang => {
    document.body.classList.remove(`lang-${lang}`)
  })
  document.body.classList.add(`lang-${lang}`)
  document.body.setAttribute('lang', lang)

  Vue.config.lang = lang
  i18n.locale = lang
}
setup()

//切换
setzhlang(){
  let LOCALE_KEY = 'localeLanguage'
  let lang = 'zh-CN'
  localStorage.setItem(LOCALE_KEY, lang)
  this.$i18n.locale = 'zh-CN'
},
setenlang(){
  let LOCALE_KEY = 'localeLanguage'
  let lang = 'en'
  localStorage.setItem(LOCALE_KEY, lang)
  this.$i18n.locale = 'en'
}

//html
{{ $t('message.orderNumber') }}
 {{ $t('message.paymentMethod') }}

./assets/lang/zh_CN这个文件夹下配置中文或是其它的语言包就要可以,然后配上前端的语言切换就可以了。还是相当易用的。

Authors get paid when people like you upvote their post.
If you enjoyed what you read here, create your account today and start earning FREE STEEM!