vue 语言包通过cookie来记录用户更改后的操作,以便每次刷新不会重置

30 篇文章 1 订阅

在这里插入图片描述

vuex代码:

import Vue from 'vue'
import Vuex from 'vuex'
import VueCookies from 'vue-cookies'

function setLang () {
  if (VueCookies.isKey('lang')) {
    return VueCookies.get('lang')
  } else {
    return 'en-US'
  }
}

const lang = setLang()
Vue.use(Vuex)
const state = {
  showFooter: true,
  changableNum: 0
}

const token = ''
const store = new Vuex.Store({
  state
})

export default {
  store,
  token,
  lang
}

由于网站每次切换语种的时候,都会保存一个cookie 例如:{ lang:‘en-US’ },并且动态设置网站语言,
在这里我引入了store.js,store里面的lang是根据cookie来赋值的,这样就保存了用户的语言习惯,在刷新页面中, VueI18n 语言管理,就会加载cookie对应的语言包,这样就大功告成了!

import VueI18n from 'vue-i18n'
import store from './store.js'
const i18n = new VueI18n({
  locale: store.lang,
  messages: {
    'zh-CN': require('./common/lang/zh'),
    'en-US': require('./common/lang/en')
  }
})

ElementLocale.i18n((key, value) => i18n.t(key, value))

/* eslint-disable no-new */
new Vue({
  el: '#app',
  i18n,
  router,
  components: {App},
  template: '<App/>'
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值