vue项目国际化实现 vue-i18n使用详细教程

1.安装vue-i18n:

npm i vue-i18n -S

固然你也能够这样:vue

<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vue-i18n/dist/vue-i18n.js"></script>

2.项目配置vue-i18n:

在src目录下建立i18n文件夹,在i18n文件夹内添加基础配置及各语言文本配置文件;vuex

在index.js进行以下设置:npm

import Vue from 'vue'; import VueI18n from 'vue-i18n'; Vue.use(VueI18n); // 引入各个语言配置文件
import zh from './config/zh'; import en from './config/en'; // 建立vue-i18n实例i18n
const i18n = new VueI18n({ // 设置默认语言
    locale: localStorage.getItem('locale') || 'zh', // 语言标识 // 添加多语言(每个语言标示对应一个语言文件)
 messages: { zh, en, } }) // 暴露i18n
export default i18n;

在各个语言配置文件中设置对应语言文案。注意:也就是说将页面中全部的文字都作成相应的语言的文件app

const zh = { name: '姓名', info: { age: '' } } export default zh;

最后在外层main.js引入i18n,并挂载至vue实例:this

import Vue from 'vue'; import App from './App.vue'; /** * 引入i18n国际化 */ import i18n from './i18n/'; Vue.config.productionTio = false; new Vue({ el: '#app', i18n, render: h => h(App) });

3.项目使用:

经过$t()方法引用文案:编码

<p>{{$t("name")}}</p>
<p>{{$t("info.age")}}</p>
<span v-text="$t('index')"></span>

修改语言:spa

this.$i18n.locale = 语言编码;
<template>
    <div id="test-ka">
        <h3>国际化翻译</h3>
        <p>{{$t("name")}}</p>
        <p>{{$t("info.age")}}</p>
        <p>
            <el-button @click.native="changeType('zh')">切换中文</el-button>
            <el-button @click.native="changeType('en')">切换英文</el-button>
        </p>
    </div>
</template>
<script> import {mapMutations} from 'vuex'; export default { date() { return {} }, methods:{ changeType(type){ // 此处作了语言选择记录
            localStorage.setItem('locale',type) // 修改显示语言
            this.$i18n.locale = type; } } } </script>
相关文章
相关标签/搜索