分享一个在WebWork中如何格式化显示数字和日期的方法:
具体的做法这里有详细的说明:
http://wiki.opensymphony.com/display/WW1/How+to+format+dates+and+numbers?showComments=true
下面是项目中推荐使用的时间格式:
#format
global.format.date={0,date,yyyy-MM-dd}
global.format.time={0,date,HH:mm:ss}
global.format.datetime={0,date,yyyy-MM-dd HH:mm:ss}
注意的是如果使用Carlender来保存时间,因为上面要求传入的是Data对象,因此需要使用Carlender.getTime()方法
从Carlender中获取Date:
<ww:text name="'global.format.date'">
<ww:param value="'birthday.time()'"/>
</ww:text>
这里使用的是<ww:param/>标签来传递参数,虽然也可以使用 <ww:text name="'format.date'" value0= "'birthday.time()'"/>
但是后面的这个方法在webwork的新版本中已经被要求不要使用,大家还是尽量使用 <ww:param/>标签
禁用value0属性的说明:
大家可以找到text标签的源代码,在com.opensymphony.webwork.views.jsp.ui.TextTag中:
public void setValue0(String aName) {
LOG.warn("The value attributes of TextTag are deprecated.");
value1Attr = aName;
}
对于数字的格式化,这里有两个参考:
global.format.percent = {0,number,##0.00'%'}
global.format.money = {0,number,$##0.00}
考虑目前在项目中使用最多的是显示附件大小,定义以下格式:
global.format.size.k={0,number,##0.00'K'}
global.format.size.m={0,number,##0.00'M'}
global.format.size.g={0,number,##0.00'G'}
如action有方法
public long getFilesize(); 返回的大小是以byte为单位,在显示时通常是以k或M显示
则显示时:
<ww:text name="'global.format.size.k'">
<ww:param value="filesize/1024"/>
</ww:text>
<ww:text name="'global.format.size.m'">
<ww:param value="filesize/1048576"/>
</ww:text>
<ww:text name="'global.format.size.g'">
<ww:param value="filesize/1073741824"/>
</ww:text>
比较遗憾的是似乎没有办法在资源文件中进行这个/1024的运算,试过{0/1024,number,##0.00'K'} 无法解析。只好在jsp里面用 value="filesize/1024"来计算实际值。不知道这里有没有别的更好的实现方式?
恩,顺便再介绍一下当时俺们team想出来的笨笨的方法,不要见笑啊,以上面的显示文件大小为例,想到的方法大致有以下几种:
1. 直接输出字符串的结果
getFileSizeString(), 在里面用java代码判断大小并生成诸如"1.2k", "31.2M"的结果返回
2. 提供多个函数
getFileSizeByte(), getFileSizeK(), getFileSizeM(), getFileSizeG()
3.使用javascript在client端格式化
<script type = "text/javascript">
var resultNum = <ww:property value="fileSize" />;
resultNum = format(resultNum);//类似的函数
document.write(resultNum);
</script>
4.使用自定义标签
--------------------------------------------------------------------------------------------------------------
struts2中格式化输出数字和日期的方法
资源文件
......
#格式化数字或时间输出
global.format.date={0,date,yyyy-MM-dd}
global.format.money={0,number,¥##0.00 '元'}
......
JSP文件
格式化时间: <s:text name="global.format.date"><s:param value="publishTime"></s:param></s:text>
格式化数字: <s:text name="global.format.money"><s:param value="price"/></s:text>
由于国际化的原因,不同的Locale对日期输入输出约定的格式是不一样的。虽然Struts2提供了<s:date> 标签,可以控制输出的格式,但是对于输入却无能为力。
这里提供一种通用的办法,既可以解决日期的输出格式的控制,又可以解决输入格式的控制,还可以推而广之,到一般数据的输入输出的格式控制。
Java代码
format.time = {0,time}
format.number = {0,number,#0.0##}
format.percent = {0,number,##0.00'%'}
format.money = {0,number,\u00A4##0.00}
format.date = {0,date,yyyy-MM-dd }
format.time = {0,time}
format.number = {0,number,#0.0##}
format.percent = {0,number,##0.00'%'}
format.money = {0,number,\u00A4##0.00}
format.date = {0,date,yyyy-MM-dd }
控制输出格式Java代码
<s:text name="format.money">
<s:param name="value" value="myValue"/>
</s:text>
<s:text name="format.money">
<s:param name="value" value="myValue"/>
</s:text>
控制输入格式Java代码
<s:textfield key="info.update_date" value="%{getText('format.number',{info.update_date})}" />
<s:textfield key="info.update_date" value="%{getText('format.number',{info.update_date})}" />
而要使已上的设定起作用,只要在国际化参数文件(.properties)中包含上面的格式设定就可以了。这也意味着我们在不同的locale环境下,可以人为设定对应的格式。
使用JSTL格式化如下方式:
<fmt:formatDate var="startdate" pattern="yyyy-MM-dd"
value="${plan.startdate }" />
${startdate } --
<fmt:formatDate var="enddate" pattern="yyyy-MM-dd"
value="${plan.enddate }" />
${enddate }