这种动态列的实现方法来自displaytag-examples-1.2.war提供的示例中,实际上下载下来的zip文件中不仅有各种jar包,还有这个包含各种例子的war包,是学习displaytag的非常好的资料。

献上完整代码:

<jsp:root version="1.2" xmlns:jsp="http://java.sun.com/JSP/Page" xmlns:display="urn:jsptld:http://displaytag.sf.net/el"
xmlns:c="urn:jsptld:http://java.sun.com/jstl/core">
<jsp:directive.page contentType="text/html; charset=UTF-8" />
<jsp:directive.page import="org.displaytag.sample.*" />
<jsp:include page="inc/header.jsp" flush="true" /> <jsp:scriptlet> // available column sets should be managed in the backend, not in the jsp page.
// you just need to build a list with Maps containing standard column attributes java.util.Map email = new java.util.HashMap();
email.put("property", "email");
email.put("title", "email title"); java.util.Map date = new java.util.HashMap();
date.put("property", "date");
date.put("title", "date");
date.put("sortable", Boolean.TRUE); java.util.Map money = new java.util.HashMap();
money.put("property", "money");
money.put("title", "money");
money.put("format", "{0,number,000.00 €}"); java.util.List set1 = new java.util.ArrayList();
java.util.List set2 = new java.util.ArrayList();
java.util.List set3 = new java.util.ArrayList(); set1.add(email);
set1.add(date);
set1.add(money); set2.add(money);
set2.add(email); set3.add(date);
set3.add(date); // this is the logic for choosing a column set
// should be done in a controller/viewer helper, not in the jsp String choose = request.getParameter("set");
if ("3".equals(choose))
{
request.setAttribute("collist", set3);
}
else if ("2".equals(choose))
{
request.setAttribute("collist", set2);
}
else
{
request.setAttribute("collist", set1);
} // just prepare the usual list
request.setAttribute( "test", new TestList(10, false) ); </jsp:scriptlet> <h2>Using predefined column lists</h2> <p>This example shows how a predefined set of columns can be applied to a table.</p>
<p>All you have to do is feeding the table with a list of beans/Maps which contains the needed column attributes and
create the needed <code><![CDATA[<display:column>]]></code> tags and use a simple iteration directly in the jsp</p>
<p>In this page we create three different set of colums, implemented as Lists of Maps, directly in the jsp. Obviously,
you will probably want to configure them in a db, xml file, or any other source for a real use (Spring xml files could
be an easy and flexible solution). No dipendence on displaytag-specific classes is required in your application, since
you can simply use a plain Map or implement a custom bean.</p>
<p>Click on a column set below to see it applied to the table.</p> <br />
<br /> <ul id="stylelist">
<li><a href="example-columnlist.jsp?set=1">column set 1</a></li>
<li><a href="example-columnlist.jsp?set=2">column set 2</a></li>
<li><a href="example-columnlist.jsp?set=3">column set 3</a></li>
</ul> <br />
<br /> <display:table name="test">
<c:forEach var="cl" items="${collist}">
<display:column property="${cl.property}" title="${cl.title}" sortable="${cl.sortable}" format="${cl.format}" />
</c:forEach>
</display:table> <jsp:include page="inc/footer.jsp" flush="true" /> </jsp:root>

整个逻辑非常简单,下面是我的分析:

(1)首先是整个例子由于非常简单,所以将数据层,控制层,显示层都放在了一个jsp文件中了,文件中也提到了实际上是不应该这么做的。

(2)再想一想到底什么是动态列?首先是同一个jsp页面(如果是不同的jsp页面,直接就是静态的就可以得到不同的显示效果),不同的时候(一般是根据不同的人具有不同的权限,额这是我猜的)得到的显示结果不一样(是指得到的结果具有不一样的列,但是其bean数据还是一样的,只是显示bean的不同属性)

(3)而我们正常情况下的操作就是<display:table></display:table>中包含若干个我们要显示的bean属性,也就是列名。我们发现<display:column>的结构是非常相似的,于是我们可以使用<c:forEach>循环输出我们想要的<c:column>即可

(4)如果要达到动态列的效果,关键在于控制<c:forEach>所遍历的集合,分析上述代码,知道该集合是一个Set,其元素是一个个Map元素。每一个Map元素对应一个bean属性,也就是一列。这个Map元素由若干个名值对组成,每个名值对就是<c:column>中的一个属性。

(5)剩下的就是点击页面上的按钮,传递不同的参数,由后台控制Set集合到底包含哪些列。还有一点需要注意,就是显示的时候,在遍历Set集合时,<c:column>中的属性必须写全,它应该包含所有的Map元素可能包含的所有属性,并不是所有的Map元素都包含同样的属性。

(6)了解了整个原理之后,在应用这个动态列的时候,最主要的反而是控制层的实现,就是说到底什么时候显示哪些列,其他时候又是显示另一些列,这必须做成容易扩展的,因为这是一个非常容易变化的需求点,甚至于突然增加一种情况。可以考虑XML文件,或者数据库保存。

displaytag 动态列实现的更多相关文章

  1. Dynamic CRM 2013学习笔记(二十六)报表设计:Reporting Service报表 动态参数、参数多选全选、动态列、动态显示行字体颜色

    上次介绍过CRM里开始报表的一些注意事项:Dynamic CRM 2013学习笔记(十五)报表入门.开发工具及注意事项,本文继续介绍报表里的一些动态效果:动态显示参数,参数是从数据库里查询出来的:参数 ...

  2. extjs动态树 动态grid 动态列

    由于项目需要做一个动态的extjs树.列等等,简而言之,就是一个都是动态的加载功能, 自己琢磨了半天,查各种资料,弄了将近两个星期,终于做出来了 首先,想看表结构,我的这个功能需要主从两张表来支持 代 ...

  3. Easy DataGrid 实现动态列、行

    Easy DataGrid 实现动态列.行 前端代码: <title>展示销售的实时数据</title> <script type="text/javascri ...

  4. 记React+.NetCore API实现动态列导出

    1.效果演示 2.用到的第三方类库 前端:React,Dva,Antd 后端:ASP.NET CORE,System.Linq.Dynamic.Core,EPPlus.Core 3.基本思路 第一:E ...

  5. datatable动态列处理,重绘表格(敲黑板,划重点!!!我肝了一天半才彻底弄懂这个东西,TAT)

    datatable动态列处理,重绘表格 前言:至于动态列的绘画,我前面博客已经写过了,就是动态列的配置问题,不懂的去我博客看下,今天要写的呢,就是你已经写了一个动态列在datatable,现在你想重新 ...

  6. [转]bootstrap table 动态列数

    原文地址:https://my.oschina.net/u/2356355/blog/1595563 据说bootstrap table非常好用,从入门教程中了解到它的以下主要功能: 由于固定表头意味 ...

  7. jquery.dataTables动态列--转

    转自 https://www.cnblogs.com/lyeo/p/4765514.html jquery.dataTables  版本1.10.7 直接上代码: 0.table <table ...

  8. jquery.dataTables动态列

    jquery.dataTables  版本1.10.7 直接上代码: 0.table <table id="popReportTable"> <thead> ...

  9. SQL Server中动态列转行

    http://www.cnblogs.com/gaizai/p/3753296.html 一.本文所涉及的内容(Contents) 本文所涉及的内容(Contents) 背景(Contexts) 实现 ...

随机推荐

  1. flowplayer+flashhls使用过程中发现的一些小问题

    flashls里边有好几套代码,主要看生成路径,其中flowplayer用了flashls.swc,flashls.swc使用的代码在这里:/src/org/mangui/hls,所以要注意,当搜索代 ...

  2. linux 防火墙--firewalld学习

    firewalld是centos7默认的防火墙,相比于iptables重要的优势: 1 支持动态更新: 2 不用重启服务: 同时增加了防火墙的“zone”概念,具体差异没做过多了解,这篇文章只记录fi ...

  3. 解决VS2013中“This function or variable may be unsafe”的问题

    1.在VS2013中编译代码时出现如上错误信息,下面就介绍下如何解决This function or variable may be unsafe的问题. 2.用VS2013打开出现错误的代码文件 3 ...

  4. HTML5最佳实践

    首先先给大家推荐个不错的 前端 网站:http://www.tystudio.net HTML5正迅速称为web前端开发技术标准,作为一名前段开发人员,了解并正确的使用HTML5制作网站变得越来越重要 ...

  5. Android 拨号器的实现 [视频1]

    Android自带了拨号功能和拨号器 这个是在一个视频里看到的    想写下来记录一下 下面放源代码 /hehe/res/layout/activity_main.xml <RelativeLa ...

  6. 『C # 开发』技能 Get√ ——制作CMD界面的简单GIF图片

    今天看到C#课本上个列子把星号(*)有规则打印在控制台中间位置 程序不难,利用的是光标定位函数Console.SetCursorPosition(x, y)做到的 心想是不是弄出一个动态的图案比较好玩 ...

  7. 转:Yelp开发团队发布内部网站设计指南

    原文来自于:http://www.infoq.com/cn/news/2014/02/yelp-style-guide 近日,Yelp开发团队在博客发布消息:Yelp公开了内部网站设计指南.这份文档此 ...

  8. Ubuntu 下启动/停止/重启mysql服务

    1:sudo start mysql 2:sudo stop mysql 3:sudo restart mysql

  9. Altium Designer 蛇行等长布线

    一. 设置需要等长的网络组 点击主菜单 Design --> Classes,在弹出的窗口中单击 Net Classes,并右键,点 Add Class 会增加一个 New Class,在该网络 ...

  10. keil #pragma disable

    μVision2 控制:这条命令不能在命令行使用,只能在源文件中使用. 功能:DISABLE 指令使得编译器在函数运行期间禁止所有中断产生.DISABLE命令必须在函数的前面以#pragma 参数的形 ...