文章目录
第四十三章 在CSP应用程序中本地化文本 - 本地化的基础
本地化的基础
当本地化应用程序的文本时,将用一种语言创建文本字符串的目录,然后建立一种约定,在应用程序地区不同时用另一种语言替换这些消息的翻译版本。
Caché支持以下本地化字符串的过程:
- 开发人员在他们的代码中包含可本地化的字符串。
在CSP应用程序中,最简单的方法是使用基于类的开发并使用$$$Text宏之一。
在硬编码字面值字符串的地方,包含$$$Text宏(或相关宏)的实例,为宏参数提供如下值:
- 默认字符串
- 该字符串所属的域(当字符串被分组到域中时,本地化更容易管理)
- 默认字符串的语言代码
&html<<div>"Hello world"</div>>
包括:
set hello=$$$Text("Hello world","sampledomain","en-us")
&html<<div>#(hello)#</div>>
-
编译代码时,编译器为
$$$Text宏(及其相关宏)的每个惟一实例在消息字典中生成条目。
消息字典是全局的,因此可以很容易地在管理门户中查看(例如)。
Caché提供类方法来帮助完成常见任务。 -
开发完成后,发布工程师为该域或所有域导出消息字典。
结果是一个或多个包含原始语言文本字符串的XML消息文件。
- 发布工程师将这些文件发送给翻译人员,要求翻译版本。
- 发布工程师将翻译后的
XML消息文件导入导出原始消息文件的同一名称空间。 - 在信息词典中,译文与原文并存。
- 在运行时,应用程序根据浏览器默认语言选择要显示的文本。
$$$Text Macros
Caché提供了三个相关的$$$Text宏(在%occMessages中)。
包含在%occInclude.inc中):
$$$Text返回一个%String$$$TextJS返回一个%String,该字符串被转义后用于JavaScript$$$TextHTML返回一个%字符串,该字符串被转义以用于HTML
每个宏都有三个参数:默认字符串、该字符串所属的域以及默认字符串的语言代码。编译代码时,编译器会在消息字典中为每组唯一的参数值生成条目。
$$$Text返回的%String可能会被赋给一个变量,可以用它来表示后续调用中的消息。例如:
Set tmsg = $$$TextJS("Error saving production")
&js<alert('#(tmsg)#: #($ZCVT($ZE,"O","JS"))#');>
或者,可以在需要字符串的任何地方插入一个$$$Text宏:
&js<alert('#($$$TextJS("Error saving production"))#: #($ZCVT($ZE,"O","JS"))#');>
参数详细信息
形式上,$$$Text、$$$TextJS和$$$TextHTML宏按顺序接受下列参数:
-
text- 非空字符串。文本必须是文字字符串。它不能是用#()#语法括起来的CSP运行时表达式的值。用于文本的格式可以是:“actualText”或:“@textId@actualText”,其中textId是消息Id,actualText是消息的文本。字符串actualText可以由下列各项单独或组合组成:- 文件格式允许的简单文本
- 替换参数
%1、%2、%3或%4 HTML格式ObjectScript字符串表达式
如果提供了
textId,则将其用作消息Id。如果未指定@textId@,系统将通过计算此文本的32位CRC(循环冗余校验)来生成新的textId。如果指定了textId,并且具有该Id的消息已经存在,则检查现有消息,看它是否具有与actualText相同的文本。否则,会报告一个错误。 -
domain- (可选)为新消息指定域的字符串。如果未指定,domain默认为编译时DOMAIN类参数的值和%response。运行时的域。(可选)
RFC 1766在指定语言的新标签代码中打开。Caché将该字符串转换为全小写。如果未指定,语言默认如下:- 编译时:
$$$DefaultLanguage。 - 在运行时:
%Response.Language,或者如果没有为%Response.Language定义值,则$DefaultLanguage。
- 编译时:
-
language- 基于标签的CSP页面会自动从浏览器设置中获取%Response.Language的值,因此它可以作为默认语言使用。对于基于类的CSP页面则不是这样,它必须显式地为%Response.Language设置一个值以将其用作默认值。可以通过在类方法MatchLanguage()中为%Response.Language赋予%Library.MessageDictionary的返回值来为其赋值,本章稍后将对此进行讨论。在给定语言列表和域名的情况下,此方法使用HTTP1.1匹配规则(RFC2616在)在域中查找最佳匹配语言。
$$$Text at Compile Time
编译包含$TEXT、$TextJS或$TextHTML宏的调用的类时,每次调用都会在消息字典中生成一条消息,其中包含宏参数提供的文本、消息ID、域和语言。
第一次通过$$$Text将消息添加到域中时,无论是否指定了语言参数,都会使用$$$SessionLanguage。同一域的后续$$$Text宏会添加与第一个添加的消息语言相同的消息。
$$$Text at Runtime
如果消息文本包含参数(%1,%2,%3,%4),必须在显示文本之前指定相应的替换文本。因为$$$Text返回一个字符串,所以可以使用编码语言自带的任何字符串操作。例如,在JavaScript中:
var prompt = '#($$$TextHTML("Remove user %1 from this Role?"))#';
prompt = prompt.replace(/%1/g,member.userName);
还可以使用$$$$Text 字符串作为%response的第一个参数。FormatText方法或$$$FormatText宏。
本文档详细介绍了在CSP(Cache Server Pages)应用程序中如何进行文本本地化,包括本地化基础、使用$$$Text宏在编译时和运行时处理文本,以及参数详细信息。开发人员可以通过包含可本地化的字符串并使用$$$Text宏,以便在不同地区使用不同语言的文本。在编译时,这些宏会在消息字典中生成条目,而在运行时,应用程序会根据浏览器的语言设置显示相应文本。
189

被折叠的 条评论
为什么被折叠?



