IBM®
跳转到主要内容
    中国 [选择]    使用条款
 
 
Select a scope:Search for:    
    首页    产品    服务与解决方案     支持与下载    个性化服务    
跳转到主要内容

developerWorks 中国  >  Java technology | Web development  >

利用标记库国际化JSP(2)

developerWorks
文档选项

未显示需要 JavaScript 的文档选项


级别: 初级

翟斌(David Zhai) (zhaibin@yahoo.com),

2002 年 8 月 20 日

本文对JSP国际化的简要介绍,着重探讨了使用标记库对JSP进行国际化的过程,并通过详细的示例演示了如何使用jakarta的i18n标记库。

综述

当我们在用JSP设计面对不同国家的站点时,特别是那些在界面之间没有特别大差别的商业站点,我们可以利用JSP的一些机制来支持国际化.

通常有三种方式可以实现国际化.

  • 为每个国家编写一套JSP代码, 可以通过嵌入BEAN和标记处理器的方式重用一些逻辑代码.
  • 维护统一的JSP代码,直接利用JAVA的资源捆绑机制实现国际化.
  • 维护统一的JSP代码,利用通用的或自定义标记库实现国际化.

我们重点讨论第三种方法,因为它有很好的灵活性,可维护性和可扩展性.

其实标记库也是利用JAVA的资源捆绑机制, 只是把国际化常用的方法封装的更容易使用,而且更符合JSP的编程思想, 把表述层和逻辑层分开.通用的标记库比较著名的有JAKARTA的I18N标记库。本文接着上一篇继续讨论i18n标记库的各种标记和使用方法,包括以下内容:

  • 对时间,日期,货币,数字国际化
  • I18N标记库的一些高级用法
  • 一个简单的例子




回页首


对时间,日期,货币,数字国际化

formatString

输出一个字符串,如果value为空则显示defaultText

<i18n:formatString value="<%= s2 %>" defaultText="the String was null"/>
 

表1:formatString的属性描述

属性名称描述
id该formatString的标识变量, 通过它,其他标记和代码可以访问该formatString,
value输出的字符串
defaultText默认的输出字符串

formatNumber

根据locale信息国际化数字,它的pattern可以定义为‘##,###.##’。如果value为空则显示defaultText,如果不设locale,则取上一级的<i18n:locale>的设定,如果没有<i18n:locale>,则根据客户端请求的locale,如果还是没有发现,则取本地JVM的locale。

<i18n:formatNumber value="<%= n %>" pattern="##,###,###.##"/>

表2:formatNumber的属性描述

属性名称描述
id该formatNumber的标识变量, 通过它,其他标记和代码可以访问该formatNumber
value输出的数字
pattern输出的模式(##,###.##)
localelocale信息
defaultText默认的输出数字

formatCurrency

根据locale信息国际化货币。如果value为空则显示defaultText,如果不设locale,则取上一级的<i18n:locale>的设定,如果没有<i18n:locale>,则根据客户端请求的locale,如果还是没有发现,则取本地JVM的locale。

<i18n:formatCurrency value="<%= n %>"/>
 

表3:formatCurrency的属性描述

属性名称描述
id该formatCurrency的标识变量, 通过它,其他标记和代码可以访问该formatCurrency
value输出的货币值
localelocale信息
defaultText默认的输出货币值

formatPercent

根据locale信息国际化百分数。如果value为空则显示defaultText,如果不设locale,则取上一级的<i18n:locale>的设定,如果没有<i18n:locale>,则根据客户端请求的locale,如果还是没有发现,则取本地JVM的locale。

<i18n:formatPercent value="<%= n %>"/>
 

表4:formatPercent的属性描述

属性名称描述
id该formatPercent的标识变量, 通过它,其他标记和代码可以访问该formatPercent
value输出的百分数
localelocale信息
defaultText默认的输出百分数

formatDateTime

根据locale信息国际化日期时间。它的dateStyle和timeStyle可以定义为'short/medium/long/full'如果value为空则显示defaultText,如果不设locale,则取上一级的<i18n:locale>的设定,如果没有<i18n:locale>,则根据客户端请求的locale,如果还是没有发现,则取本地JVM的locale。

<i18n:formatDateTime dateStyle="medium" timeStyle="medium"/>

表5:formatDateTime的属性描述

属性名称描述
id该formatDateTime的标识变量, 通过它,其他标记和代码可以访问该formatDateTime
value输出的日期时间
locale指定的locale信息
dateStyle输出的日期格式
timeStyle输出的时间格式
defaultText默认的输出日期和时间

formatDate

根据locale信息国际化日期。它的style可以定义为(short/medium/long/full),pattern可定义为'YYYY MMM ddd'.如果value为空则显示defaultText,如果不设locale,则取上一级的<i18n:locale>的设定,如果没有<i18n:locale>,则根据客户端请求的locale,如果还是没有发现,则取本地JVM的locale。

<i18n:formatDate pattern="yyyy MMMMM ddd hh:mm:ss"/>

表6:formatDate的属性描述

属性名称描述
id该formatDate的标识变量, 通过它,其他标记和代码可以访问该formatDate
value输出的日期
locale指定的locale信息
pattern日期的模式(YYYY MMM ddd)
Style日期的格式(short/medium/long/full)
defaultText默认的输出日期

formatTime

根据locale信息国际化日期。它的style可以定义为(short/medium/long/full).如果value为空则显示defaultText,如果不设locale,则取上一级的<i18n:locale>的设定,如果没有<i18n:locale>,则根据客户端请求的locale,如果还是没有发现,则取本地JVM的locale。

<i18n:formatTime style="full"/>

表7:formatTime的属性描述

属性名称描述
id该formatTime的标识变量, 通过它,其他标记和代码可以访问该formatTime
value输出的时间
locale指定的locale信息
Style日期的格式(short/medium/long/full)
defaultText默认的输出日期





回页首


I18N标记库的一些高级用法

ifdef

判断一个key是否存在于指定(或默认)的资源文件中,如果存在则进行该标记中的语句.

<i18n:ifdef key="zh_CN_ONLY">
Only users specifying zh_CN as their locale will see this!
</i18n:ifdef>

表8:ifdef的属性描述

属性名称描述
key欲判断是否在资源文件中的key的名字
bundleResourceBundle的基本名,可以连同locale信息定位所需的ResourceBundle.
bundleRef一个包含ResourceBundle的属性名,通常为bundle的id

ifndef

判断一个key是否存在于指定(或默认)的资源文件中,如果不存在则进行该标记中的语句.

<i18n:ifndef key="zh_CN_ONLY">
Only users specifying something OTHER than zh_CN\
as their locale will see this!
</i18n:ifndef>

表9:ifndef的属性描述

属性名称描述
key欲判断是否在资源文件中的key的名字
bundleResourceBundle的基本名,可以连同locale信息定位所需的ResourceBundle.
bundleRef一个包含ResourceBundle的属性名,通常为bundle的id





回页首


一个简单的例子

<%--
this page contains a variety of demonstrations of the <i18n:formatXXX> tags
--%>
<%@ taglib uri="http://jakarta.apache.org/taglibs/i18n-1.0" prefix="i18n" %>
<i18n:bundle baseName="i18n-test" id="bundle"/>
<%@ page import="java.util.Date" %>
<%@ page import="java.util.Locale" %>
<html>
<head>
<title>Examples of using the Formatting tags in the i18n Tag Library Tag</title>
</head>
<body>
<%
Number n = new Double( 1234567.89 );
Date d = new Date();
%>
<h2>default Locale</h2>
<h3>The time is now:-</h3>
<ul>
<li>
<i18n:formatTime style="medium" /> (medium)
</li>
</ul>
<h3>The date is now:-</h3>
<ul>
<li>
<i18n:formatDate pattern="yyyy MMMMM ddd hh:mm:ss"/> (pattern)
</li>
</ul>
<h3>The datetime is now:-</h3>
<ul>
<li>
<i18n:formatDateTime dateStyle="full" timeStyle="full"/> (full, full)
</li>
</ul>
<h3>The number is:-</h3>
<ul>
<li>
<i18n:formatNumber value="<%= n %>"/> (number)
</li>
<li>
<i18n:formatNumber value="<%= n %>" pattern="##,###,###.##"/> (number with pattern)
</li>
<li>
<i18n:formatCurrency value="<%= n %>"/> (currency)
</li>
<li>
<i18n:formatPercent value="<%= n %>"/> (percent)
</li>
</ul>
<h2>US Locale</h2>
<i18n:locale locale="<%= Locale.US %>">
<h3>The time is now:-</h3>
<ul>
<li>
<i18n:formatTime style="medium" /> (medium)
</li>
</ul>
<h3>The date is now:-</h3>
<ul>
<li>
<i18n:formatDate pattern="yyyy MMMMM ddd hh:mm:ss"/> (pattern)
</li>
</ul>
<h3>The datetime is now:-</h3>
<ul>
<li>
<i18n:formatDateTime dateStyle="full" timeStyle="full"/> (full, full)
</li>
</ul>
<h3>The number is:-</h3>
<ul>
<li>
<i18n:formatNumber value="<%= n %>"/> (number)
</li>
<li>
<i18n:formatNumber value="<%= n %>" pattern="##,###,###.##"/> (number with pattern)
</li>
<li>
<i18n:formatCurrency value="<%= n %>"/> (currency)
</li>
<li>
<i18n:formatPercent value="<%= n %>"/> (percent)
</li>
</ul>
</i18n:locale>
<h2> ifdef </h2>
<i18n:ifdef key="zh_CN_ONLY">
<i18n:message key="zh_CN_ONLY" />
</i18n:ifdef>
<h2> ifndef </h2>
<i18n:ifndef key="zh_CN_ONLY">
Only users specifying something OTHER than zh_CN
as their locale will see this!
</i18n:ifndef>
</body>
</html>

i18n-test.properties

OHTER_ONLY = a test

i18n-test_zh_CN.properties

zh_CN_ONLY = 只有locale是zh_CN时才可以看到我!

注意要把资源文件拷贝到/WEB-INF/classes子目录下





回页首


标记库和源代码下载

taglibs.zip

关于作者

翟斌(David Zhai)毕业与北京航空航天大学自动控制专业,学士学位。毕业后一直从事软件开发工作,对网络安全,国际化/本地化有一定的研究。现任职于北京一家开发软件国际化工具的专业公司,从事软件国际化工具的研发。联系方式: zhaibin@yahoo.com




对本文的评价

太差! (1)
需提高 (2)
一般;尚可 (3)
好文章 (4)
真棒!(5)

建议?




回页首


IBM 公司保留在 developerWorks 网站上发表的内容的著作权。未经IBM公司或原始作者的书面明确许可,请勿转载。如果您希望转载,请通过 提交转载请求表单 联系我们的编辑团队。
    关于 IBM 隐私条约 联系 IBM 使用条款