实现多语言配置的 Vue 3 项目

在 Vue 3 项目中,通过使用vue-i18n 库可以方便地实现多语言配置,为用户提供多语言支持的界面体验。在本篇博客中,我将向您介绍如何在 Vue 3 项目中配置和使用多语言功能,让您的应用能够支持多种语言。让你的开发起来更加简单。

步骤一:安装 vue-i18n

首先,在您的 Vue 3 项目中安装vue-i18n 库。您可以通过以下命令来安装:

npm install vue-i18n@next

步骤二:创建语言文件

在src下创建一个语言文件夹,用来存放语言配置文件(en.js,zh.js,i18n.js)三个文件,我这个项目只需要中英文,现在做一个简单使用示例
在这里插入图片描述
具体的文件:
en.js:(英文翻译文件夹)

//en
export default {
  message: {
   home: 'home'
  }
}

zh.js:(中文)

export default {
  message: {
   home: '首页'
  }
}

i18n.js:

import { createI18n } from "vue-i18n";
import en from './en'
import zh from './zh';
 
const i18n = createI18n({
  locale:localStorage.getItem('language') || 'zh', // 默认是中文
  globalInjection:true,//全局配置$t
  legacy:false,
  messages:{en,zh}// 需要做国际化的语种
 
})
 
export default i18n

然后在main.js里头配置全局的语言
main.js:

import './assets/main.css'

import { createApp } from 'vue'
import pinia from '@/stores/index.js'

import App from './App.vue'
import router from './router'
import i18n from './lang/i18n';

const app = createApp(App) 
app.use(router)
app.use(pinia)
app.use(i18n)

app.mount('#app')

配置好这些以后就可以使用了:
切换中英文的文件:

<template>
    <div class="entry_box">
      <div class="entry_head">
        <button @click="changeLocale">{{ currentLocale === 'en' ? 'Switch to Chinese' : '切换英文' }}</button>
      </div>
      <div class="entry_main">
        <div class="menu">
          <Menu/>
        </div>
        <div class="main">
          <router-view>
          </router-view>
        </div>
      </div>
    </div>
  </template>
  <script setup>
  import { ref } from 'vue';
  import Menu from '@/components/Menu.vue'
  import { useI18n } from 'vue-i18n';
  const { locale, t } = useI18n();
  locale.value = 'zh';
  const currentLocale = ref(locale.value);
  const changeLocale = () => {
    currentLocale.value = currentLocale.value === 'zh' ? 'en' : 'zh';
    locale.value = currentLocale.value;
  };
  </script>
  <style scoped lang="less">
  .entry_box{
    height: 100%;
    width: 100%;
    .entry_head{
      height: 64px;
      width: 100%;
      display: flex;
      background: #409eff;
    }
    .entry_main{
      width: 100%;
      height: calc(100vh - 64px);
      display: flex;
      .menu{
        width: 1;
        height: calc(100vh - 64px);
      }
      .main{
        padding: 10px;
        flex: 1;
        height: calc(100vh - 64px);
      }
    }
  }
  
  </style>
  

在菜单配置项里头做语言切换的监听

<template>
  <div class="menu_box">
    <el-menu
      active-text-color="#d71921"
      background-color="#fff"
      class="el-menu-vertical-gat"
      :default-active="defaultActive"
      text-color="#040c2c"
      :collapse="isCollapse"
      @open="handleOpen"
      @close="handleClose"
      ref="menuRef"
    >
      <template v-for="item in menuData" :key="item.index">
        <el-sub-menu v-if="item.children && item.children.length > 0" :index="item.index">
          <template #title>
            <span>{{ item.title }}</span>
          </template>
          <el-menu-item v-for="citem in item.children" :index="citem.index" :key="citem.index" @click="changeMenu(citem)">
            {{ citem.title }}
          </el-menu-item>
        </el-sub-menu>
        <el-menu-item v-else :index="item.index" @click="changeMenu(item)">
          <el-icon><component :is="item.icon"></component></el-icon>
          <span>{{ item.title }}</span>
        </el-menu-item>
      </template>
    </el-menu>
  </div>
</template>

<script setup>
import { ref, onMounted, onBeforeUnmount, watch, markRaw, onUpdated } from 'vue';
import { Document, Menu as IconMenu, Location, Setting } from '@element-plus/icons-vue';
import { useRoute, useRouter } from 'vue-router';
import { useI18n } from 'vue-i18n'
  const { locale, t } = useI18n();
  const router = useRouter()
  const defaultActive = ref('1');
  const isCollapse = ref(false);
  const menuRef = ref(null);
  const menuData = ref([]);

  const initMenuData = () => {
    menuData.value = [
      {
        index: '1',
        title: t('message.home'),
        name: 'home',
        icon: markRaw(Location)
      },
      {
        index: '2',
        title: '系统管理',
        name: 'systemManagement',
        icon: markRaw(Setting),
        
      },
      {
        index: '3',
        title: '网关配置',
        name: 'equipmentConfig',
        icon: markRaw(IconMenu)
      },
      {
        index: '4',
        title: '日志管理',
        name: 'logManagement',
        icon: markRaw(Document)
      }
    ];
  }
  // 监听语言变化,并重新初始化菜单数据
  watch(locale, () => {
    initMenuData();
  });
  // 初始化菜单数据
  initMenuData();
  const setCollapseState = (windowWidth) => {
    if (windowWidth < 768) {
      isCollapse.value = true;
    } else {
      isCollapse.value = false;
    }
  }

  const handleOpen = (key, keyPath) => {
    if(menuRef&&menuData){
          for(let i=0;i<menuData.length;i++){
            let menu = menuData[i];
            if(menu.index!=key&&menu.children&&menu.children.length>0){
              //关闭其他sub-menu
              menuRef.close(menu.index);
            }
          }
        }

    // if (key !== defaultActive.value && menuData.value) {
    //   menuData.value.forEach((menu) => {
    //     if (menu.index !== key && menu.children && menu.children.length > 0) {
    //       menu.$refs.menuRef.close(menu.index);
    //     }
    //   });
    // }
  }

  const handleClose = (key, keyPath) => {
    // Handle close logic here
  }

  const changeMenu = (item) => {
    console.log(item);
    router.push({ name: item.name });
    // this.$router.push({ name: item.name });
  }

  onMounted(() => {
    setCollapseState(window.innerWidth);
    window.addEventListener('resize', () => {
      setCollapseState(window.innerWidth);
    });
  });

  onBeforeUnmount(() => {
    window.removeEventListener('resize', setCollapseState);
  });

</script>

<style scoped lang="less">
.menu_box {
  height: 100%;

  .el-menu {
    height: 100%;
  }
}
</style>

效果如下:
在这里插入图片描述
在这里插入图片描述

结语

通过以上步骤,您已经成功配置了 Vue 3 项目的多语言功能。用户可以通过切换语言来改变应用中显示的文字内容,为不同语言用户提供更好的用户体验。这只是一个简单的配置,后续还需要把切换的语言放到store中,以便其他地方使用。希望这篇博客对您有帮助!

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 项目实现语言配置的方法很多,其中一种常见的做法是使用 `vue-i18n` 库。下面是使用 `vue-i18n` 实现语言配置的步骤: 1. 安装 `vue-i18n` 库。 ```shell npm install vue-i18n --save ``` 2. 在 `main.js` 中引入 `vue-i18n` 库,并初始化配置。 ```javascript import Vue from 'vue' import VueI18n from 'vue-i18n' import App from './App.vue' Vue.use(VueI18n) const i18n = new VueI18n({ locale: 'en', // 设置默认语言为英语 messages: { en: { greeting: 'Hello!' }, zh: { greeting: '你好!' } } }) new Vue({ el: '#app', i18n, render: h => h(App) }) ``` 在上面的代码中,首先引入 `vue-i18n` 库,并通过 `Vue.use()` 方法将其安装到 Vue 中。然后,初始化 `VueI18n` 实例,并设置默认语言为英语,同时设置了英语和中文两种语言的翻译内容。 3. 在组件中使用 `$t` 方法来获取翻译内容。 ```html <template> <div> <p>{{ $t('greeting') }}</p> </div> </template> ``` 在上面的代码中,我们使用 `$t` 方法来获取 `greeting` 这个翻译内容。`$t` 方法会根据当前语言环境自动获取对应的翻译内容,如果找不到对应的翻译,则会返回原始字符串。 4. 在页面中添加语言切换按钮,以便用户可以切换不同的语言。 ```html <template> <div> <p>{{ $t('greeting') }}</p> <button @click="switchLang('en')">English</button> <button @click="switchLang('zh')">中文</button> </div> </template> <script> export default { methods: { switchLang(lang) { this.$i18n.locale = lang // 切换语言 } } } </script> ``` 在上面的代码中,我们添加了两个按钮,分别用于切换为英语和中文。当用户点击按钮时,会触发 `switchLang` 方法来切换当前的语言环境。在 `switchLang` 方法中,我们通过修改 `$i18n.locale` 属性来切换当前语言环境。 通过上面的步骤,我们就可以在 Vue 项目实现语言配置了。当用户切换语言时,页面中的文本内容会自动切换为对应的翻译内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值