前言:大概在去年6月的时候,我们团队开始使用webwork来替代struts,刚开始大家都没有经验,为了格式化输出时间和数字,想出了很多现在看来笨笨的傻傻的方法。后来俺找到了这个方法,试验了一下之后发了下面这个email给了team member, 今天一位同事问起这个问题,俺从数以千计的已发送邮件中找到了这个东西,想想决定整理出来。给大家分享一下,顺便给我自己做个备份,呵呵,后者基本上是俺写blog的一个重要用途。
分享一个在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.使用自定义标签
分享到:
相关推荐
webwork中文帮助文档 webwork中文帮助文档 webwork中文帮助文档 webwork中文帮助文档 webwork中文帮助文档 webwork中文帮助文档
webwork中文 webwork中文参考 webwork中文资料 webwork学习资料
webwork2.17中文使用手册
webwork中文文档
webwork中上传文件,webwork文件上传.doc
webwork2中文参考
webwork 2.2.6 中文版本,然后编译生成chm格式,方面查看。
webwork2中文文档,是一个比较的中文文档
webwork2中文教程,实例讲述教材。
WEBWORK的配置
自己学习webwork的参考手册,适合初学者
webWork中文教程
WebWork完全自学!
NULL 博文链接:https://goowolf.iteye.com/blog/521195
webwork源码下载
详细的介绍了webwork的使用机制和标签的归类使用
webwork教程webwork教程webwork教程webwork教程webwork教程webwork教程webwork教程webwork教程webwork教程webwork教程webwork教程webwork教程
WEBWORK的源文件压缩包WEBWORK的源文件压缩包WEBWORK的源文件压缩包WEBWORK的源文件压缩包WEBWORK的源文件压缩包WEBWORK的源文件压缩包WEBWORK的源文件压缩包WEBWORK的源文件压缩包WEBWORK的源文件压缩包
这是webwork1的jar包,还有webwork-2.2.7.jar和webwork-src-2.2.7.jar
WebWork类型转换 List Boolean 等他类型的转换 可以通过页面