TA的每日心情 | 开心 2021-3-12 23:18 |
---|
签到天数: 2 天 [LV.1]初来乍到
|
本文是良葛格先生在http://www.javaworld.com.tw上发表的系列文章之一。
本文的测试代码请在本站下载。将下载的testjsf目录放入tomcat的webapps目录下,启动tomcat,然后在浏览器中输入:
http://localhost:8080/testjsf/pages/index.faces
JSF的国际化(Internnationalization)信息处理是基于Java对国际化的支援,您可以在一个信息资源档中统一管理信息资源,资源文件的名称是.properties,而�容是名称与值的配对,例如:
messages.properties
titleText=JSF Demo
hintText=Please input your name and password
nameText=name
passText=password
commandText=Submit
资源档名称由basename加上语言与地区来组成,例如:
basename.properties
basename_en.properties
basename_zh_TW.properties
�有指定语言与地区的basename是预设的资源档名称,JSF会根据浏览器送�的Accept-Language header中的�容来�定该使用哪一个资源档名称,例如:
Accept-Language: zh_TW, en-US, en
如果浏览器送来这些header,则预设会使用繁体中文,接著是美式英文,再来是英文语系,如果找不到对应的信息资源档,则会使用预设的信息资源档。
由于信息资源档必�是ISO-8859-1编码,所以对于非西方语系的处理,必须先将之转换为Java Unicode Escape格式,例如您可以先在信息资源档中写下以下的�容:
messages_zh_TW.txt
titleText=JSF示�
hintText=��入名��密�
nameText=名�
passText=密�
commandText=送出
然后使用JDK的工具程式native2ascii来转换,例如:
native2ascii -encoding Big5 messages_zh_TW.txt messages_zh_TW.properties
转换后的�容会如下:
messages_zh_TW.properties
titleText=JSFu793au7bc4
hintText=u8acbu8f38u5165u540du7a31u8207u5bc6u78bc
nameText=u540du7a31
passText=u5bc6u78bc
commandText=u9001u51fa
(所有资源文件放入你的JFS应用的WEB-INF/classes目录下)
接下来您可以使用<f:loadBundle>标记�指定载入信息资源,一个例子如下:
index.jsp
<%@ taglib uri="http://java.sun.com/jsf/core" prefix="f" %>
<%@ taglib uri="http://java.sun.com/jsf/HTML" prefix="h" %>
<%@page contentType="text/html;charset=UTF8"%>
<f:view>
<f:loadBundle basename="messages" var="msgs"/>
<html>
<head>
<title><h:outputText value="#{msgs.titleText}"/></title>
</head>
<body>
<h:form>
<h3><h:outputText value="#{msgs.hintText}"/></h3>
<h:outputText value="#{msgs.nameText}"/>:
<h:inputText value="#{user.name}"/><p>
<h:outputText value="#{msgs.passText}"/>:
<h:inputSecret value="#{user.password}"/><p>
<h:commandButton value="#{msgs.commandText}"
actionListener="#{user.verify}"
action="#{user.outcome}"/>
</h:form>
</body>
</html>
</f:view>
如此一�,如果您的浏览器预设接受zh_TW语系的话,则页面上就可以显示中文,否�预设将以英文显示,也就是messages.properties的�容,为了能显示多国语系,我们设定网页编码为UTF8。
<f:view>可以设定locale属性,直接指定所要使用的语系,例如:
<f:view locale="zh_TW">
<f:loadBundle basename="messages" var="msgs"/>
直接指定以上的�,则会使用繁体中文来显示,JSF会根据<f:loadBundle>的basename属性加上<f:view>的locale属性��定要使用哪一个信息资源档,就上例而言,就是使用messages_zh_TW.properties,如果设定为以下的话,就会使用messages_en.properties:
<f:view locale="en">
<f:loadBundle basename="messages" var="msgs"/>
您也可以在faces-config.xml中设定语系,例如:
<faces-config>
<application>
<local-config>
<default-locale>en</default-locale>
<supported-locale>zh_TW</supported-locale>
</local-config>
</application>
.....
</faces-config>
在<local-config>一定有一个<default-locale>,而<supported-locale>可以有好几个,这告�JSF您的应用程序支援哪些语系。
当然,如果您可以提供一个选项让使用者选择自己的语系会是更好的方式,例如根据user这个Bean的locale属性来决定页面语系:
<f:view locale="#{user.locale}">
<f:loadBundle basename="messages" var="msgs"/>
在页面中设定一个表单,可以让使用者选择语系,例如设定单选钮:
<h:selectOneRadio value="#{user.locale}">
<f:selectItem itemValue="zh_TW"
itemLabel="#{msgs.zh_TWText}"/>
<f:selectItem itemValue="en"
itemLabel="#{msgs.enText}"/>
</h:selectOneRadio>
本文的测试代码请在本站下载。
function TempSave(ElementID)
{
CommentsPersistDiv.setAttribute("CommentContent",document.getElementById(ElementID).value);
CommentsPersistDiv.save("CommentXMLStore");
}
function Restore(ElementID)
{
CommentsPersistDiv.load("CommentXMLStore");
document.getElementById(ElementID).value=CommentsPersistDiv.getAttribute("CommentContent");
}
源码下载:http://file.javaxxz.com/2014/10/10/025349109.zip |
|