vue+vant国际化i18n用法

1.安装i18n npm install vue-i18n -S

2.在src目录下创建一个lang文件夹,内建三个文件:index.js en_us.js zh_cn.js

en_us.js代码如下:

export default {
    app: {
        hello: 'Hello,World'
    }
}

zh_cn.js代码如下:

export default {
    app: {
        hello: '你好,世界!'
    }
}

index.js代码如下:

import Vue from 'vue'
import VueI18n from 'vue-i18n'
import {Locale} from 'vant'
import enUS from 'vant/lib/locale/lang/en-US'
import zhCN from 'vant/lib/locale/lang/zh-CN'
import enLocale from './en_us'
import zhLocale from './zh_cn'

Vue.use(VueI18n)

const messages = {
    en: {
      ...enUS,
      ...enLocale
    },
    zh: {
      ...zhCN,
      ...zhLocale
    }
  }
  
  const i18n = new VueI18n({
    locale: 'zh',  // 设置默认语言
    messages: messages // 设置资源文件对象
  })
  
  // 更新vant组件库本身的语言变化,支持国际化
  function vantLocales (lang) {
    if (lang === 'en') {
      Locale.use(lang, enUS)
    } else if (lang === 'zh') {
      Locale.use(lang, zhCN)
    }
  }
  
  export {i18n, vantLocales}

3.修改src/main.js文件内容:

import {i18n, vantLocales} from './lang'

vantLocales(i18n.locale)

new Vue({
    router,
    store,
    i18n,
    render: h => h(App)
  }).$mount('#app');

4.使用:

<template>
  <div>语言设置
    <van-nav-bar :title="this.$t('app.hello')" @click-left="show=true">
      <van-icon name="search" slot="left" />
    </van-nav-bar>
    <button @click="changeLang">切换语言</button>
  </div>
</template>
<script>
export default {
  data() {
    return {};
  },
  methods:{
    changeLang(){
      this.$i18n.locale == 'en'? this.$i18n.locale = 'zh':this.$i18n.locale = 'en'
    }
  }
};
</script>

5.用你的左手的手心,大力的和右手的手心接触。

  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值