vue - - - - Vue3+i18n多语言动态国际化设置

前言

继续【如何给自己的网站添加中英文切换】一文之后,后续新开发项目在开发时就要进行多语言环境配置,此文记录Vue3+i18n使用的过程。

一、 i18n 介绍

i18n:Vue.js 的国际化插件。Vue I18n (kazupon.github.io)

它可以轻松地将一些本地化功能集成到你的 Vue.js 应用程序中

二、插件安装

npm install  vue-i18n@9 --save 
// or 
yarn add  vue-i18n@9 --save

注意:需要注意的是vue3最好使用9.x以上的版本!

三、i18n配置

3.1 创建i18n对应文件夹/文件

在这里插入图片描述

注意:文件名可以随意,但是后续需要对应上!!!

3.2 en-US.js

export default {
  languageTxt: "简体中文", // 当前语言模式下 可切换的语言模式

  // 头部信息
  headTxt: {
    // 用户相关
    user: {
      name: "ZhangSan",
      btnTxt: "log out",
    },
  },

  // 菜单
  menuList: [
    {
      title: "Home",
    },
    {
      title: "User Management",
    },
    {
      title: "Commodity management",
    },
  ],
};

3.3 zh-CN.js

export default {
  languageTxt: "en-US", // 当前语言模式下 可切换的语言模式

  // 头部信息
  headTxt: {
    // 用户相关
    user: {
      name: "张三",
      btnTxt: "退出",
    },
  },

  // 菜单
  menuList: [
    {
      title: "首 页",
    },
    {
      title: "用户管理",
    },
    {
      title: "商品管理",
    },
  ],
};

注意:en-US以及 zh-CN两个文件内的数据结构需要保持一致!!!

3.4 index.js

import { createI18n } from "vue-i18n";
import zhCN from "./locales/zh-CN";
import enUS from "./locales/en-US";

let language = localStorage.getItem("language") || navigator.language; //  获取本地存储 || 根据浏览器语言设置


const i18n = createI18n({
  legacy: false, // 使用Composition API,这里必须设置为false
  locale: language, // 默认显示语言
  globalInjection: true, // 全局注册$t方法
  messages: {
    "zh-CN": zhCN,
    "en-US": enUS,
  },
});

export default i18n;

四、 mian.js 引入 i18n配置文件

在这里插入图片描述

五、 组件内使用

有三种方式示例⬇️

// namespace: "index" 
<template>
  <div class="index-container">
    展示locales配置的内容:
     <br>

    <!-- 方式一、直接页面内使用 : 更改locale.value时 可直接自动切换对应语言 -->
    方式一: {{ $t("headTxt.user.name") }}
    <br />

    <!-- 方式二、使用变量方式 : 看起来简洁明,但是更改locale.value时, 不能够自动切换对应语言!!!! -->
    方式二:{{ state.name }}
    <br />

    <!-- 方式三、使用变量方式+computed计算属性 简洁明了,更改locale.value时。也能够自动切换对应语言!!!!!!!! -->
    方式二:{{ state.computedName }}
    <br />

    <!-- 切换语言模式按钮  (方式一、直接页面内使用 好处:更改locale.value时 可直接自动切换对应语言)-->
    <button @click="changeLanguage">
      {{ $t("languageTxt") }}
    </button>
  </div>
</template>
<script>
// 国际化
import { useI18n } from "vue-i18n";
import i18nLanguage from "@/language";
import { reactive, computed } from "vue";
export default {
  name: "index",
  setup() {
    const I18n = useI18n();
    let { locale } = I18n;
    // 可以拿到我们当前设置的默认语言,切换语言更改locale.value的值即可,
    // 但要和你language/index.js中message设置的key的值一致!!!
    // 如果有需要,可以在store中配置一个然后全局使用

    const state = reactive({
      name: i18nLanguage.global.t("headTxt.user.name"),
      computedName: computed(() => i18nLanguage.global.t("headTxt.user.name")),
    });

    /**
     * 切换语言
     */
    const changeLanguage = () => {
      locale.value = locale.value == "zh-CN" ? "en-US" : "zh-CN"; // 切换中英文
    };

    return { state, locale, changeLanguage };
  },
};
</script>
<style lang="scss" scoped>
.index-container {
}
</style>

注意:$t为i18n所调用方法,全局引入即可用!

六、使用效果

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

  • 26
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值