news 2026/5/16 14:06:16

VonaJS: I18n如何支持Swagger多语言

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
VonaJS: I18n如何支持Swagger多语言

初始化代码骨架

我们先在模块demo-student中初始化I18n的代码骨架

1. Cli命令

$ vona :init:locale demo-student

2. 菜单命令

右键菜单 - [模块路径]: `Vona Init/Locale`

定义语言资源

以模块demo-student为例,定义模块的语言资源:

英文

src/module/demo-student/src/config/locale/en-us.ts

export default {

+ StudentName: 'Student Name',

};

中文

src/module/demo-student/src/config/locale/zh-cn.ts

export default {

+ StudentName: '学生名称',

};

使用语言资源

可以通过 Scope 实例提供的locale对象获取模块的语言资源,支持类型化提示

class ControllerStudent {

@Web.get('test')

test() {

// use current locale

const message1 = this.scope.locale.StudentName();

// use locale en-us

const message2 = this.scope.locale.StudentName.locale('en-us');

// use locale zh-cn

const message3 = this.scope.locale.StudentName.locale('zh-cn');

console.log(message1, message2, message3);

}

}

跨模块使用语言资源

class ControllerStudent {

@Web.get('test')

test() {

// use current locale

const message1 = this.$scope.demoStudent.locale.StudentName();

// use locale en-us

const message2 = this.$scope.demoStudent.locale.StudentName.locale('en-us');

// use locale zh-cn

const message3 = this.$scope.demoStudent.locale.StudentName.locale('zh-cn');

console.log(message1, message2, message3);

}

}

覆盖语言资源

可以使用项目级别的语言资源覆盖模块级别的语言资源

英文

src/backend/config/locale/en-us.ts

export default {

modules: {

+ 'demo-student': {

+ StudentName: 'Student Name!',

+ },

},

};

中文

src/backend/config/locale/zh-cn.ts

export default {

modules: {

+ 'demo-student': {

+ StudentName: '学生名称!',

+ },

},

};

当前locale

1. 获取当前locale

const locale = this.ctx.locale;

2. 设置当前locale

this.ctx.locale = 'en-us';

3. 获取缺省locale

const localeDefault = this.$scope.i18n.config.defaultLocale;

获取当前locale的规则

当用户访问后端 API 时,后端会自动根据规则获取当前 locale

1. 模块配置

I18n 是由模块 a-i18n 提供的核心能力,可以在 App config 中修改模块的配置:

src/backend/config/config/config.ts

// modules

config.modules = {

'a-i18n': {

defaultLocale: 'en-us',

queryField: 'x-vona-locale',

headerField: 'x-vona-locale',

cookieField: 'locale',

},

};

名称 说明

defaultLocale Default locale

queryField 从request query中获取当前locale,query key默认为x-vona-locale

headerField 从request header中获取当前locale,header key默认为x-vona-locale

cookieField 从request cookie中获取当前locale,cookie key默认为locale

2. 规则次序

系统按以下次序,依次判断当前 locale

queryField > headerField > cookieField > Header: Accept-Language > defaultLocale

添加新语言

VonaJS 默认提供了两个语言:en-us和zh-cn。下面演示如何添加新语言zh-tw

1. 添加类型定义

采用接口合并机制添加新语言的类型定义

在 VSCode 编辑器中,输入代码片段recordlocale,自动生成代码骨架:

declare module 'vona' {

export interface ILocaleRecord {

: never;

}

}

调整代码,然后添加zh-tw

declare module 'vona' {

export interface ILocaleRecord {

+ 'zh-tw': never;

}

}

2. 添加语言资源

新建语言文件zh-tw.ts,然后添加语言资源

src/module/demo-student/src/config/locale/zh-tw.ts

export default {

StudentName: '學生名稱',

};

复数

1. 定义语言资源

src/module/demo-student/src/config/locale/en-us.ts

export default {

+ TestApples_: '%d apples',

+ TestApples_0: 'no apples',

+ TestApples_1: 'one apple',

};

src/module/demo-student/src/config/locale/zh-cn.ts

export default {

+ TestApples_: '%d个苹果',

+ TestApples_0: '没有苹果',

};

2. 使用语言资源

this.ctx.locale = 'en-us';

const apple0 = this.scope.locale.TestApples_(0);

const apple1 = this.scope.locale.TestApples_(1);

const apple2 = this.scope.locale.TestApples_(2);

console.log(`${apple0}, ${apple1}, ${apple2}`);

控制台输出如下:

no apples, one apple, 2 apples

TestApples_: 缺省语言资源。语言资源添加后缀_,可以提示开发者该语言资源需要传入参数

TestApples_{n}: 可以针对任何具体的n提供独立的语言资源。系统在进行语言翻译时,如果找不到具体n的语言资源,就使用缺省语言资源TestApples_

复数: 多参数

如果语言资源支持多参数,那么可以明确指定哪个参数支持复数

1. 定义语言资源

src/module/demo-student/src/config/locale/en-us.ts

export default {

+ TestNameApples_: '%s has %d apples',

+ TestNameApples_0_1: '%s has no apples',

+ TestNameApples_1_1: '%s has one apple',

};

src/module/demo-student/src/config/locale/zh-cn.ts

export default {

+ TestNameApples_: '%s有%d个苹果',

+ TestNameApples_0_1: '%s没有苹果',

};

2. 使用语言资源

this.ctx.locale = 'en-us';

const apple0 = this.scope.locale.TestNameApples_('Tom', 0);

const apple1 = this.scope.locale.TestNameApples_('Tom', 1);

const apple2 = this.scope.locale.TestNameApples_('Tom', 2);

console.log(`${apple0}, ${apple1}, ${apple2}`);

控制台输出如下:

Tom has no apples, Tom has one apple, Tom has 2 apples

TestNameApples_: 缺省语言资源。语言资源添加后缀_,可以提示开发者该语言资源需要传入参数

TestNameApples_{n}_{ordinal}: ordinal代表参数序数

Swagger/Openapi

VonaJS 提供了一组工具函数,为 Swagger/Openapi 实现 I18n 国际化

比如,为EntityStudent的字段name提供国际化的title信息

1. $localeScope

在设置字段 title 信息时,要使用语言资源FullKey。在实际生成 Swagger/Openapi 元数据时,系统会自动将语言资源FullKey翻译为指定的语言

+ import { $localeScope } from 'vona';

class EntityStudent {

+ @Api.field(v.title($localeScope('demo-student', 'Name')))

name: string;

}

v.title: 设置 title 信息

$localeScope: 传入模块名称和语言资源Key,从而生成语言资源FullKey: demo-student::Name

2. $locale

VonaJS 还提供了一个简化的工具函数$locale

+ import { $locale } from '../.metadata/index.ts';

class EntityStudent {

+ @Api.field(v.title($locale('Name')))

name: string;

}

$locale: 传入语言资源Key,从而生成语言资源FullKey: demo-student::Name

每个模块都提供了$locale 函数,因此,使用本模块的$locale 函数就可以取得模块名称

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/16 14:05:17

大厂生存启示录:从“螺丝钉”到“金牌个人”的 9 次关键跃迁

大厂生存启示录:从“螺丝钉”到“金牌个人”的 9 次关键跃迁 *请关注公众号【碳硅化合物AI】 你是否也在大厂的洪流中感到迷茫?每天面对写不完的代码、修不完的 Bug,不仅担心被定义为“工具人”,更害怕自己真的沦为一颗随时可被…

作者头像 李华
网站建设 2026/5/11 10:21:55

5分钟掌握GitHub入门教程优化:从零基础到高效协作

5分钟掌握GitHub入门教程优化:从零基础到高效协作 【免费下载链接】introduction-to-github Get started using GitHub in less than an hour. 项目地址: https://gitcode.com/GitHub_Trending/in/introduction-to-github 想要快速掌握GitHub的使用技巧&…

作者头像 李华
网站建设 2026/5/10 5:39:29

快速上手:Color Thief智能配色方案实战指南

快速上手:Color Thief智能配色方案实战指南 【免费下载链接】color-thief Grab the color palette from an image using just Javascript. Works in the browser and in Node. 项目地址: https://gitcode.com/gh_mirrors/co/color-thief 面对品牌视觉统一和网…

作者头像 李华
网站建设 2026/5/9 23:55:01

A16z 谈 AI 留存的「水晶鞋效应」:第一个月,决定了一切 都是一次认真“试鞋”的机会:这一次,能不能真的解决我手里的问题?

A16z 谈 AI 留存的「水晶鞋效应」:第一个月,决定了一切 原创 Cubo Group 矩阵魔方AI出海 2025年12月12日 19:45 陕西 在传统 SaaS 时代,有一条几乎没人怀疑的共识:产品早期留存差,是正常现象。 MVP 功能不全&#…

作者头像 李华
网站建设 2026/5/15 15:15:10

5、深入了解 Ubuntu 网络配置与 X Window 系统

深入了解 Ubuntu 网络配置与 X Window 系统 1. Ubuntu 无线网络配置 在过去,为 Linux 系统配置无线网络是一件非常繁琐的事情,需要执行许多复杂的步骤才能连接到无线网络。不过,现在情况有了很大的改善。Ubuntu 系统中包含了一个名为 Network Manager 的实用工具,它让连接…

作者头像 李华
网站建设 2026/5/5 10:21:06

分享几则中年夫妻关系的有益建议

著名演员何晴去世了,很震惊,她是我最喜欢的女演员,曾经出演过四大名著。分享几则中年夫妻关系的有益建议: 1、可以容忍对方的生活习惯。包括拉S放P、不叠被、不洗衣,但要管好自己,还是尽量别过份坦荡。 2、…

作者头像 李华