JeeSite 4.x 国际化(i18n)、多语言、本地化

半腔热情 提交于 2020-03-23 17:17:53

3 月,跳不动了?>>>

1、支持登录时,指定语言,或登录后进行语言切换(param_lang=en)

2、支持 Cookie 存储语言设置,没有 Cookie 的情况使用 Session 存储,支持移动端

3、支持 properties 文件、数据库存储译文,方便译文数据进行管理。

4、可翻译:固定数据(如:页面标题、标签、消息提示)、动态数据(如:菜单数据、字典数据等)

5、中文免写 zh_CN 译文,如:text(‘你好’),找不到对应 key 直接原样输出 “你好”

6、支持 kay 和译文参数,如:text(‘今天第{0}天’, 3),输出 “今天第3天”

语言文件

后端语言文件

固定数据语言

不会变化的文字翻译,如:某个提示信息,字段 label,列表标题,按钮文字等,这些译文需要放到 properties 里。

文件目录结构,支持模块化分类语言文件结构,如下:

/src/main/resources/messages/模块编码/i18n_语言编码.properties

例如:msg 模块 en 译文配置:

/src/main/resources/messages/msg/i18n_en.properties

文件内容:

  • 文件内容采用 key=value 方式存储,如:你好=Hello
  • 若Key中包含空格,可使用“\”转义,如:提\ 交=Submit
  • 带参数的译文,如:今天第\ {0}\ 天。= Today is the {0} day.

在系统字典中维护新增加的语言:sys_lang_type,字典编码为语言编码;

动态数据语言

业务或管理员可通过数据库进行修改或配置的一些文字译文,如菜单名称,字典名称,字典值等。

这些可通过 system 账号登录,进入菜单 “系统管理 -> 系统设置 -> 国际化管理” 添加译文。

前端语言文件

根据需求自己扩展语言文件,例如:

<script src="${ctxStatic}/modules/i18n/i18n_${lang()}.js" ></script>

举例内容如下:

window.jeesiteMessage = $.extend({}, window.jeesiteMessage, {
    '你好' : 'Hello',
    '今天第 {0} 天' : ' Today is the {0} day.'
});

语言调用方法

Java

1、获取语言名称:Global.getLang()

返回:en、zh_CN

2、获取语言编码译文:Global.getText(code)

例如:Global.getText("你好")

3、获取语言编码译文,支持参数:Global.getText(code, params...)

例如:Global.getText("今天第{0}天", 3)

4、在集成 BaseController 和 BaseService 的类里可直接通过

例如:text(code) 或 text(code, params...)

Beetl视图

1、获取语言名称:${lang()}

返回:en、zh_CN

2、获取语言编码译文:${text(code)}

例如:${text("你好")}

3、获取语言编码译文,支持参数:${text(code, params...)}

例如:${text("今天第{0}天", 3)}

JavaScript

1、获取语言名称:window.lang || 'zh_CN'

返回:en、zh_CN

2、获取语言编码译文:text(code)

例如:text("你好")

3、获取语言编码译文,支持参数: text(code, params...)

例如:text("今天第{0}天", 3)

常用语言编码

java.util.Locale :

public static final Locale ENGLISH = createConstant("en", "");
public static final Locale FRENCH = createConstant("fr", "");
public static final Locale GERMAN = createConstant("de", "");
public static final Locale ITALIAN = createConstant("it", "");
public static final Locale JAPANESE = createConstant("ja", "");
public static final Locale KOREAN = createConstant("ko", "");
public static final Locale CHINESE = createConstant("zh", "");
public static final Locale SIMPLIFIED_CHINESE = createConstant("zh", "CN");
public static final Locale TRADITIONAL_CHINESE = createConstant("zh", "TW");
public static final Locale FRANCE = createConstant("fr", "FR");
public static final Locale GERMANY = createConstant("de", "DE");
public static final Locale ITALY = createConstant("it", "IT");
public static final Locale JAPAN = createConstant("ja", "JP");
public static final Locale KOREA = createConstant("ko", "KR");
public static final Locale CHINA = SIMPLIFIED_CHINESE;
public static final Locale PRC = SIMPLIFIED_CHINESE;
public static final Locale TAIWAN = TRADITIONAL_CHINESE;
public static final Locale UK = createConstant("en", "GB");
public static final Locale US = createConstant("en", "US");
public static final Locale CANADA = createConstant("en", "CA");
public static final Locale CANADA_FRENCH = createConstant("fr", "CA");

语言代码表:http://www.lingoes.cn/zh/translator/langcode.htm

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!