Ant-design-vue + vue-i18n实现前端国际化

项目基于Vue-cli3.x进行开发,使用了ant-design-vue框架,然后需要做国际化。此时做国际化需要考虑两方面的国际化,一是ant-design-vue内部组件的国际化,二是国际化我们的业务显示,业务显示我们选用vue-i18n进行国际化。

安装vue-i18n

yarn add vue-i18n

在public文件夹下新建languages文件夹,在新建langs文件夹和i18n.js,langs文件夹下新建index.js、cn.js、en.js。

d9e5d24dafd6d4d9ec5811ec1861f22e.png

i18n.js文件内容如下:

2dd2499bc140f7ee37cd36a3564fe021.png

langs下index.js内容如下:

e5c3929b0902bb579cd5138d8055ab9b.png

langs下cn.js内容如下(en.js文件和cn格式一样):

73395d00d887db589570ce90551d3940.png

在main.js中导入语言包

5f151a60c84547a30ba5c2683f1853cd.png

比较基础的配置我们已经配置好了,接下来我们写切换多语言功能,在src下的app.vue文件中引入多语言文件和我们写切换的方法:

399484a166f51119bd2aaa9f6203cbb6.png

c094460296ad48a37184c0c6f8afa9b0.png

created内容如下:

created() {
    // 默认中文
    localStorage.lang == undefined ? localStorage.setItem("lang", "cn") : "";
    // 自己配置多语言适配
    this.$root.Bus.$on("switchLanguage", value => {
      let router_path = this.$route.path;
      switch (value) {
        case "cn":
          localStorage.setItem("lang", "cn");
          break;
        case "en":
          localStorage.setItem("lang", "en");
          break;
      }
      // 刷新页面
      this.isRouterAlive = false; //先关闭,
      this.$nextTick(function() {
        this.isRouterAlive = true; //再打开
      });
      // 系统组件适配
      let lang = localStorage.lang;
      if (lang == "cn") {
        this.locale = cn;
        moment.locale("cn");
      } else if (lang == "en") {
        this.locale = en;
        moment.locale("en");
      } 
    });
  },

上面这个方法可以简单理解就是我们在这里定义了一个方法,在别的组件我们只要调用这个方法就可以切换多语言。调用方法如下:

this.$root.Bus.$emit("switchLanguage", "cn/en");

解释下this.$root.Bus.$on(),这个是组件传值的一种方式,需要在main.js中配置,

2bdb6c81e531f1c9d780b20426d01887.png

moment.locale("cn");这个是ant-design-vue内部组件的国际化切换方法。

页面适配多语言分为view中使用和js中

view中我们用

:label="$t('logistics.search')"

或者

{{$t('logistics.search')}}

js中我们用

this.$t("logistics.search")

简单测试下切换多语言,在login.vue(你可以是任意组件中)写调用方法

733fc5d0f85118f996870916b1f0fe88.png

1df1426e90ac3e1672d6169d7114abd1.png

显示效果

418624db750251d559e68531a35ec007.png

48d8a901c06fb8e44324c5a867921427.png

多语言适配完成,但是,如果我们系统文字多,那一个文件会很大,加载很慢,对用户不友好,那我们优化下,一个vue组件我们对一个json多语言文件,按需加载

这里我们用到了vue的mixin,src下新建mixins文件夹,新建一个utils.js文件,内容格式如下:

7058085a8f07ebdde229c1fabb95a9c6.png

/**
         * 引入语言包
         * @param path
         */
        importFontpack(path) {
            let _nowMsg = require('@/languages/' + path + localStorage.lang + '.json');
            this.$i18n.mergeLocaleMessage(localStorage.lang, _nowMsg);
            this.$i18n.locale = localStorage.lang
        },

src下新建languages文件夹,下面分模块

3c4928eb52fdfa682a6be135b55e7115.png

页面切换多语言

b6b6d0d1df71d314d0d11e3987b8d28c.png

c17f010d820e2083163e58dfcb7baeb5.png

这样就完成了Ant-design-vue + vue-i18n实现前端国际化。

posted @ 2022-05-31 18:10  青年码农  阅读(717)  评论(0编辑  收藏  举报