您好,欢迎访问一九零五行业门户网

jQuery easyUI中实现表格的跨行跨列的方法

代码:
页面访问数据的部分
$(function (){ $('#dg').datagrid({ url:'tablecontroller.do?gettable&field=itemid,productid,listprice,unitcost,attr1,status', singleselect:true, collapsible:true,//收起表格的内容 width: 700, height: 450, loadmsg: '数据加载中...', singleselect:true, fitcolumns:true, rownumbers: true,//显示行数 idfield: 'itemid', pagination:true,//显示分页 pagesize:20, pagenumber:1, pagelist:[20,40,60,80,100], columns:[[ {field:'',title:'95598账目计算表',colspan:6,align:'center',height:30} ],[ {field:'itemid',title:'部门名称',rowspan:2,align:'center'}, {field:'',title:'统计各部门的账目总和:50亿美元',colspan:5,align:'right'} ],[ {field:'productid',title:'目录',width:100,align:'center'}, {field:'listprice',title:'部门一',width:100,align:'center'}, {field:'unitcost',title:'部门二',width:100,align:'center'}, {field:'attr1',title:'部门三',width:100,align:'center'}, {field:'status',title:'部门四',width:100,align:'center'} ]], onloadsuccess: function (data) { if (data.rows.length > 0) { //调用mergecellsbyfield()合并单元格 mergecellsbyfield("dg", "itemid"); // 重新载入当前页面数据 settimeout("$('#dg').datagrid('reload');",5000); } } }); $('#dg').datagrid('getpager').pagination({ beforepagetext:'', afterpagetext:'/{pages}', displaymsg:'{from}-{to}共 {total}条', showpagelist:true, showrefresh:true, onbeforerefresh:function(pagenumber, pagesize){ $(this).pagination('loading'); $(this).pagination('loaded'); } });
/**
* easyui datagrid根据字段动态合并单元格
* 参数 tableid 要合并table的id
* 参数 collist 要合并的列,用逗号分隔(例如:”name,department,office”);
*/
function mergecellsbyfield(tableid, collist) { var colarray = collist.split(","); var ttable = $("#" + tableid); var tablerowcnts = ttable.datagrid("getrows").length; var tmpa; var tmpb; var pertxt = ""; var curtxt = ""; var alertstr = ""; for (j = colarray.length - 1; j >= 0; j--) { pertxt = ""; tmpa = 1; tmpb = 0; for (i = 0; i <= tablerowcnts; i++) { if (i == tablerowcnts) { curtxt = ""; } else { curtxt = ttable.datagrid("getrows")[i][colarray[j]]; } if (pertxt == curtxt) { tmpa += 1; } else { tmpb += tmpa; ttable.datagrid("mergecells", { index: i - tmpa, field: colarray[j],//合并字段 rowspan: tmpa, colspan: null }); ttable.datagrid("mergecells", { //根据colarray[j]进行合并 index: i - tmpa, field: "ideparture", rowspan: tmpa, colspan: null }); tmpa = 1; } pertxt = curtxt; } } }
后端模拟的数据,只要前台能够收到数据,将最基本的表格显示出来,调用mergecellsbyfield(tableid, collist)
即可,他是将数据加载完成之后在进行单元格合并的。数据只是为了测试是否能够正确显示
/**
*
* 测试显示表格内容的方法
* @return
*/
@requestmapping(params = "gettable") public void gettable(httpservletrequest request, httpservletresponse response, datagrid datagrid) { list<map<string, object>> listresults=new arraylist<map<string,object>>(); string[] str = {"满意数","不满意数","满意率","合计","部门的总共数","部门满意率"}; string[] item = {"满意度","消息","评价","总计"}; int j = 0;int k = 0; try { for (int i = 0; i < 24 ; i++) { map<string, object> map = new hashmap<string, object>(); if(i/6==j){ map.put("itemid", item[j]); map.put("productid", str[k]); map.put("listprice", new random().nextint(100)); map.put("unitcost", new random().nextint(100)); map.put("attr1", new random().nextint(100)); map.put("status", new random().nextint(100)); k++; }else{ ++j; k=0; map.put("itemid", item[j]); map.put("productid", str[k]); map.put("listprice", new random().nextint(100)); map.put("unitcost", new random().nextint(100)); map.put("attr1", new random().nextint(100)); map.put("status", new random().nextint(100)); k++; } listresults.add(map); } int page = datagrid.getpage(); int rows = datagrid.getrows(); list<map<string, object>> listresultsend=new arraylist<map<string,object>>(); for (int i = (page-1)*rows; i < page*rows; i++) { if(listresults.size()>=(i+1)){ listresultsend.add(listresults.get(i)); } } datagrid.setresults(listresultsend); datagrid.settotal(listresults.size()); tagutil.datagrid(response, datagrid); } catch (exception e) { e.printstacktrace(); } }
以上就是jquery easyui中实现表格的跨行跨列的方法的详细内容。
其它类似信息

推荐信息