这段时间在用displayTag, 它有很多好用的功能,俺也不就在这赘述,当然也有几个不方便的地方. 比如求和后"%"的显示等与求和相关的缺点, 这里先介绍一个缺点并把我从网上整理出来的解决方案也一并帖出.
问题是这样的: 由于业务要求, 当用户鼠标位于表中某一列的标头时, 在这个表头"动画"地显示这列的简介.
先看下做出来的效果:
若不用displaytag的话,这个没什么困难的, 直接加mouseOver事件就OK了.可现在用dispalyTag后, 在<display:column ..>中加不了onMouseOver的响应事件,即便是能加这个响应事件的话, 也是加到了列上, 没法定位到当前列的表头.
怎么解决?
写DisplayTag的装饰器应该可以,但太麻烦.
在JSP上做文章吧.
那只能用JavaScript了, 以前用Dojo时有这个效果,但仅仅为了这么个功能引入Dojo显然很不划算.
自己写一个JavaScript方法.
先在网上搜下看看有没有类似的解决方法, 终于找到一个:
http://www.devx.com/webdev/10MinuteSolution/31020/0/page/3,看样子行, 于是就以他的方法为出发点来写.还有一哥们,他想改写displatTag的部分源码以支持那些常见的JavaScript事件.
http: //jira.codehaus.org/browse/DISPL-187. 这个牛人的问题咱们以后再研究.
回到咱们的主题上来. 以他的RowHandlers.js为出发点怎么写? 分为三步:
先看第一步, 这个是有些麻烦,若不是用了FireFox里的firebug来跟踪查看DOM,这一步就写不出来. 写了改,改了再调了N遍后, 终于成功了:
var theadCells = document.getElementById(tableID).getElementsByTagName("thead")[0].rows[0].cells;
这个theadCells就是HTML中表头上的一系列<tr></tr>. tableID是传来的参数, 毕竟displayTag还没"干尽杀绝", 让咱们程序员得到生成table的id.
再看第二步, 这个没什么可说的, 直接按人家方法来就行了:
写到这后,用浏览器打开当用户鼠标处于目标位置时, 就有一个可能的"Hello"给alter出来了.写到这也顺便赞叹下像JavaScript这样的动态语言,不用编译太方便了, 不像Java那样写一个Hiberante的Dao实现后,若没有配置像JUnit那样测试环境的话,为了试下费老劲了.
应该说第二步写完后, javaScript与displatTag的一次合作就算完成了, 下面的第三步与本主题有些远了, 以后我再记录写这样"动画"效果的体会吧.
--------------------------------------------------------
真是抱歉,昨天有些匆忙,忘了把示例代码也一并贴上来, 现在补上(见附件). 它只能在IE里用, 当鼠标位于"ID"上时, 就有"Hello, Guys!"出来.