Tips:本篇已加入系列文章阅读目录,可点击查看更多相关文章。

前言

上一篇介绍了ABP扩展实体,并且在前端部分新增了身份认证管理和租户管理的菜单,在实现这两个功能模块前,先来解决一下界面文字国际化的问题。

开始

国际化(简称 I18N),本地化(简称 L10N);这两者的目的都是用于让你的应用程序支持多个国家和区域的语言,它们看起来很相似,但是有一些细微的区别,本文不对此进行深入探讨,有兴趣的可以自行搜索。ABP后端支持的是本地化,而vue-element-admin支持的是国际化,使用vue-i18n实现;本文默认它两者是一回事。

前面的章节中,已经大概分析了vue+ABP国际化的实现思路。我们可以在后端实现国际化,然后vue从后端获取国际化文本,展示到界面中;另一种方式是直接在前端部分实现国际化。在前端实现就很简单,直接在vue-element-admin的src\lang\目录下配置相应的文本,然后界面使用i18n的$t()方法渲染就可以了,这个不多做介绍。本文只探讨第一种实现方式。

语言选项

首先,语言选项列表需要根据后端配置得到。

在后端修改支持的语言类型,这里就只支持中文和英文2种吧,其他的注释掉。

src\Xhznl.HelloAbp.HttpApi.Host\HelloAbpHttpApiHostModule.cs:

请求abp/application-configuration接口:

此时返回的localization.languages属性只有2个语言了,然后只需要把这个数据绑定到界面上就好了。语言切换用的是一个公共组件 src\components\LangSelect\index.vue:

  1. <template>
  2. <el-dropdown
  3. trigger="click"
  4. class="international"
  5. @command="handleSetLanguage"
  6. >
  7. <div>
  8. <svg-icon class-name="international-icon" icon-class="language" />
  9. </div>
  10. <el-dropdown-menu slot="dropdown">
  11. <el-dropdown-item
  12. v-for="item in languages"
  13. :key="item.cultureName"
  14. :disabled="language === item.cultureName"
  15. :command="item.cultureName"
  16. >
  17. {{ item.displayName }}
  18. </el-dropdown-item>
  19. </el-dropdown-menu>
  20. </el-dropdown>
  21. </template>
  22. <script>
  23. export default {
  24. data() {
  25. return {
  26. languages: this.$store.getters.abpConfig.localization.languages
  27. };
  28. },
  29. computed: {
  30. language() {
  31. return this.$store.getters.language;
  32. }
  33. },
  34. methods: {
  35. handleSetLanguage(lang) {
  36. //this.$i18n.locale = lang
  37. this.$store.dispatch("app/setLanguage", lang);
  38. this.$store.dispatch("app/applicationConfiguration").then(() => {
  39. this.$message({
  40. message: "Switch Language Success",
  41. type: "success"
  42. });
  43. });
  44. }
  45. }
  46. };
  47. </script>

语言切换

语言切换时,需要再次调用app/applicationConfiguration接口,更新本地化文本。

src\utils\request.js:

  1. // request interceptor
  2. service.interceptors.request.use(
  3. config => {
  4. // do something before request is sent
  5. config.headers['accept-language'] = store.getters.language
  6. if (store.getters.token) {
  7. config.headers['authorization'] = 'Bearer ' + getToken()
  8. }
  9. return config
  10. },
  11. error => {
  12. // do something with request error
  13. console.log(error) // for debug
  14. return Promise.reject(error)
  15. }
  16. )

src\store\modules\app.js:

  1. const actions = {
  2. 。。。。。。
  3. applicationConfiguration({ commit }) {
  4. return new Promise((resolve, reject) => {
  5. applicationConfiguration()
  6. .then(response => {
  7. const data = response;
  8. commit("SET_ABPCONFIG", data);
  9. const language = data.localization.currentCulture.cultureName;
  10. const values = data.localization.values;
  11. setLocale(language, values);
  12. resolve(data);
  13. })
  14. .catch(error => {
  15. reject(error);
  16. });
  17. });
  18. }
  19. };

src\lang\index.js:

  1. import Vue from "vue";
  2. import VueI18n from "vue-i18n";
  3. import Cookies from "js-cookie";
  4. import elementEnLocale from "element-ui/lib/locale/lang/en"; // element-ui lang
  5. import elementZhLocale from "element-ui/lib/locale/lang/zh-CN"; // element-ui lang
  6. Vue.use(VueI18n);
  7. const messages = {
  8. en: {
  9. ...elementEnLocale
  10. },
  11. "zh-Hans": {
  12. ...elementZhLocale
  13. }
  14. };
  15. export function getLanguage() {
  16. const chooseLanguage = Cookies.get("language");
  17. if (chooseLanguage) return chooseLanguage;
  18. // if has not choose language
  19. const language = (
  20. navigator.language || navigator.browserLanguage
  21. ).toLowerCase();
  22. const locales = Object.keys(messages);
  23. for (const locale of locales) {
  24. if (language.indexOf(locale) > -1) {
  25. return locale;
  26. }
  27. }
  28. return "en";
  29. }
  30. export function setLocale(language, values) {
  31. i18n.mergeLocaleMessage(language, values);
  32. i18n.locale = language;
  33. }
  34. const i18n = new VueI18n({
  35. // set locale
  36. // options: en | zh | es
  37. locale: getLanguage(),
  38. // set locale messages
  39. messages
  40. });
  41. export default i18n;

将后端返回的文本设置到vue-i18n中,就可以使用了。这跟直接在前端做国际化有一点区别就是,后者的文本信息是写在前端,vue-i18n可以直接使用。而这里只是把文本信息改到后端,从后端获取后再设置到i18n中,本质是一样的。

修改后端的配置文本:

src\Xhznl.HelloAbp.Domain.Shared\Localization\HelloAbp\zh-Hans.json:

src\Xhznl.HelloAbp.Domain.Shared\Localization\HelloAbp\en.json:

localization.values返回:

接下来只需要把界面上对应的文本使用vue-i18n的$t()方法渲染就好了,比如:

前端需要改动的地方比较多,但都是类似的修改。。。直接看效果:

注意

因为app/applicationConfiguration接口只有在刷新页面、登录、退出、切换语言等操作的时候才会去调用,所以不用担心请求频繁。

其实上面有一部分本地化文本还是放在了前端:ElementUI自带的文本。因为ABP的本地化json格式只能有一级,key/value:

文本只能写在texts属性中,key/value形式,不支持多层级。

而vue-i18n是支持多层级的:

所以ElementUI的这部分文本还是放在前端了。

最后

本篇关于vue+ABP实现国际化就介绍完了。。。其实还是有点繁琐的,要配置的比较多,不知道有没有更好的方法,欢迎评论交流。。。

初识ABP vNext(6):vue+ABP实现国际化的更多相关文章

  1. 初识ABP vNext(1):开篇计划&基础知识

    目录 前言 开始 审计(Audit) 本地化(Localization) 事件总线(Event Bus) 多租户(multi-tenancy technology) DDD分层 实体(Entity) ...

  2. ABP VNext框架基础知识介绍(1)--框架基础类继承关系

    在我较早的时候,就开始研究和介绍ABP框架,ABP框架相对一些其他的框架,它整合了很多.net core的新技术和相关应用场景,虽然最早开始ABP框架是基于.net framework,后来也全部转向 ...

  3. [Abp vNext微服务实践] - 服务通讯

    简介 服务通讯是微服务架构中必不可少的功能,服务通讯的效率决定了微服务架构的优略.常用的微服务通讯策略有两种,分别是rpc.http,其中rpc以gRpc框架为代表使用者最多.abp vNext微服务 ...

  4. 我和ABP vNext 的故事

    Abp VNext是Abp的.NET Core 版本,但它不仅仅只是代码重写了.Abp团队在过去多年社区和商业版本的反馈上做了很多的改进.包括性能.底层的框架设计,它融合了更多优雅的设计实践.不管你是 ...

  5. [Abp vNext 源码分析] - 20. 电子邮件与短信支持

    一.简介 ABP vNext 使用 Volo.Abp.Sms 包和 Volo.Abp.Emailing 包将短信和电子邮件作为基础设施进行了抽象,开发人员仅需要在使用的时候注入 ISmsSender ...

  6. 初识ABP vNext(3):vue对接ABP基本思路

    目录 前言 开始 登录 权限 本地化 创建项目 ABP vue-element-admin 最后 前言 上一篇介绍了ABP的启动模板以及AbpHelper工具的基本使用,这一篇将进入项目实战部分.因为 ...

  7. 初识ABP vNext(7):vue身份认证管理&租户管理

    Tips:本篇已加入系列文章阅读目录,可点击查看更多相关文章. 目录 前言 开始 按钮级权限 身份认证管理 R/U权限 权限刷新 租户管理 租户切换 效果 最后 前言 上一篇介绍了vue+ABP国际化 ...

  8. Vue获取Abp VNext Token

    Abp VNext默认没公开访问Token的Api,但有个问题Cookie方式如果是手机或桌面程序不如Token方便 Axios默认是Json方式提交,abp登录需要使用application/x-w ...

  9. Vue Abp vNext用户登录(Cookie)

    因为Abp vNext没找到Vue的模板,网上也没找到相关vNext的例子,只能自己试着写写,asp.net core abp vue都是刚学不久,所以很粗糙也可能有错误的地方,如果您看到请指正,谢谢 ...

随机推荐

  1. JVM详解之:HotSpot VM中的Intrinsic methods

    目录 简介 什么是Intrinsic Methods 内置方法的特点 多样性 兼容性 java语义的扩展 Hotspot VM中的内置方法 intrinsic方法和内联方法 intrinsic方法的实 ...

  2. PHP array_splice() 函数

    实例 从数组中移除元素,并用新元素取代它: <?php$a1=array("a"=>"red","b"=>"gr ...

  3. PDO::commit

    PDO::commit提交一个事务(PHP 5 >= 5.1.0, PECL pdo >= 0.1.0) 说明 语法 bool PDO::commit ( void )高佣联盟 www.c ...

  4. 4.23 子集 分数规划 二分 贪心 set 单峰函数 三分

    思维题. 显然考虑爆搜.然后考虑n^2能做不能. 容易想到枚举中间的数字mid 然后往mid两边加数字 使其整个集合权值最大. 这里有一个比较显然的贪心就不再赘述了. 可以发现这样做对于集合是奇数的时 ...

  5. Selenium多窗口切换代码

    # #!/usr/bin/python3 # -*- coding: utf-8 -*- # @Time : 2020/7/31 16:05 # @Author : Gengwu # @FileNam ...

  6. day10.函数基础及函数参数

    一.函数 功能:包裹一部分代码 实现某一个功能 达成某一个目的 特点: """ 特点:可以反复调用,提高代码的复用性,提高开发效率,便于维护管理 函数基本格式 函数的定义 ...

  7. 非常适合小白的 Asyncio 教程

      非常适合小白的 Asyncio 教程 原文:https://segmentfault.com/a/1190000008814676 所谓「异步 IO」,就是你发起一个 IO 操作,却不用等它结束, ...

  8. Taurus.MVC 2.3.4 :WebAPI 文档集成测试功能升级:WebAPI批量自动化测试功能。

    前言: 最近升级了一下Taurus.MVC,现在最新版本是:Taurus.MVC 2.3.4,源码版本和nuget同步. 下面分三个步骤介绍下新版本的WebAPI批量自动化测试功能. 1.启用WebA ...

  9. UI自动化填写问卷(selenium)+定时任务(懒人必备)

    1.自动填报 UI自动化 selenium 开发程序动机:天天有人催着填写问卷,弄的头大.主要还是懒的每天一个个去填写内容. 开发总时长:2个小时:学习+开发+修改 遇到的小问题: 在自动化填写地图的 ...

  10. C语言学习笔记之输出缓冲

    在c语言中经常用到输出函数printf,当我们像往常一样在输出函数中输入我们的想要的输出的东西后加\n换行 验证结果如我们输出的一样 如果我们在后面加入死循环会不会出现这些语句呢 结果卡死了,可还是输 ...