vue3 i18n 多语言切换

vue3中实现多语言切换

  1. 下载插件 npm install vue-i18n@next,@next表示安装i18n 最新的 vue3的版本
  2. 创建 language 文件夹,并创建 i18n.ts

i18n.ts 文件示例

js 复制代码
// i18n.ts
 
import { createI18n } from 'vue-i18n'
import zh from './zh'
import en from './en'

const i18n = createI18n({
    legacy: false, // 使用CompotitionAPI必须添加这条.
    locale: 'zh', // 默认语言
    // fallbackLocale: 'en', // 默认第二语言
    messages: {
        zh,
        en
    }
})

export default i18n

zh.ts 文件示例

js 复制代码
//.ts
export default {
  header: {
    langLable: '选择语言',
    langZH: '中文',
    langEN: '英文',
  },
  setting: {
    settingsModuleMenuTree: {
      General: '常规设置',
      Account: '账号设置',
      Email: '邮箱设置',
      Calendar: '日历设置',
      Interface: '界面布局',
      Keyboard: '快捷键设置',
      Extended: '扩展功能',
      About: '关于SEmail...',
    },
    homeText: '显示名称',
    mineText: '个人中心'
  },
}

en.ts 文件示例

js 复制代码
//en.ts
export default {
  header: {
    langLable: 'Select Language',
    langZH: 'Chinese',
    langEN: 'English',
  },
  setting: {
    settingsModuleMenuTree:{
      General: 'General Settings',
      Account: 'Account Settings',
      Email: 'Email settings',
      Calendar: 'Calendar Settings',
      Interface: 'Interface Layout',
      Keyboard: 'Keyboard shortcuts',
      Extended: 'Extended functionality',
      About: 'About SEmail',
    },
    homeText: 'homepage',
    mineText: 'Personal Center'
  },
}
  1. main.ts 中注册 i18n
js 复制代码
1.  // main.ts
1.  import i18n from './language/i18n'
1.
1.  const app = createApp(App)
1.  ...
1.  app.use(i18n) // 挂载语言包
  1. 点击按钮切换语言
js 复制代码
<template>
	<div>
		 <el-select :placeholder="t('header.langLable')" style="width:155px">
              <el-option :label="t('header.langZH')" value="zh" @click="changeLanguage('zh')" />
              <el-option :label="t('header.langEN')" value="en" @click="changeLanguage('en')" />
            </el-select>
	</div>
</template>
js 复制代码
<script lang = 'ts' setup>
import { useI18n } from 'vue-i18n'
const { locale, t } = useI18n()

const changeLanguage = (value: string) => {
	locale.value = value
}
<script>
  1. 在需要文字说明的组件中使用
js 复制代码
// 使用的 xxx.vue
<script setup lang="ts">
    import { useI18n } from "vue-i18n";
    const { t } = useI18n()
</script>
 
<template>
     <p>{{t('setting.homeText') }} </p>
     <el-form-item :label="t('setting.homeText') + ':'">
        <el-input v-model="accountAppDisplay" placeholder="界面上, 显示的名称" />
     </el-form-item>
</template>
js 复制代码
<span>{{$t("setting.homeText")}}</span>

注意,$t()是个函数,"setting.homeText"是它的参数,是一个字符串,相当于传入了对象的key值。
如果需要动态绑定怎么办呢,比如,我们循环渲染,如下段代码所示:

js 复制代码
{{$t('setting.settingsModuleMenuTree.' + item.value)}}
js 复制代码
<template>
  <div>
    <el-menu class="menu">
            <el-menu-item v-for="(item, idx) in settingsModuleMenuTree" :index="idx + ''" class="menu-item">
              {{$t('setting.settingsModuleMenuTree.' + item.value)}}
            </el-menu-item>
          </el-menu>
  </div>
</template>
<script setup lang="ts">
    import { useI18n } from "vue-i18n";
    const { t } = useI18n()
    
    const settingsModuleMenuTree = ref<any[]>([]);
    settingsModuleMenuTree.value = [
      { name: "常规设置", value: 'General' },
      { name: "账号设置", value: 'Account' },
      { name: "邮箱设置", value: 'Email' },
      { name: "日历设置", value: 'Calendar' },
      { name: "界面布局", value: 'Interface' },
      { name: "快捷键设置", value: 'Keyboard' },
      { name: "扩展功能", value: 'Extended' },
      { name: "关于SEmail...", value: 'About' },
    ];
</script>
相关推荐
晴殇i5 分钟前
前端工程师必须掌握的SEO实战指南
前端·javascript·面试
problc19 分钟前
CSS 工具对比:UnoCSS vs Tailwind CSS,谁是你的菜?
前端·css
天天摸鱼的java工程师24 分钟前
互联网行业能力解刨:从Java后端八年开发经验看
前端·后端·程序员
brzhang31 分钟前
Android 16 卫星连接 API 来了,带你写出「永不失联」的应用
前端·后端·架构
John_ToDebug1 小时前
Chrome 浏览器前端与客户端双向通信实战
前端·c++·chrome
要加油哦~1 小时前
CSS | transition 和 transform的用处和区别
前端·css
小鱼人爱编程1 小时前
现代大前端是如何编码的?
android·前端·flutter
神仙别闹1 小时前
基于Java+VUE+MariaDB实现(Web)仿小米商城
java·前端·vue.js
袁煦丞1 小时前
低成本私有云存储方案Nas-Cab:cpolar实验室第508次成功挑战
前端·程序员·远程工作
小公主1 小时前
「前端必备」Flex 布局全解析:从入门到深度计算,搞懂弹性盒子!
前端·css