这次给大家带来实现带分组数据Table表头排序功能,实现带分组数据Table表头排序功能的注意事项有哪些,下面就是实战案例,一起来看一下。
如下图:
要求:点击表头排序时,”分组”及”分组明细”的数据层次关系不变
从网上找了一段常规的table排序,改了改,以满足“分组支持”,贴在这里备份
- .tbl-list, .tbl-list td, .tbl-list th { border: solid 1px #000; border-collapse: collapse; padding: 10px; margin: 15px; }
table sort //排序 tableId: 表的id,iCol:第几列 ;dataType:iCol对应的列显示数据的数据类型 function sortAble(th, tableId, iCol, dataType) { var ascChar = "▲"; var descChar = "▼"; var table = document.getElementById(tableId); //排序标题加背景色 for (var t = 0; t < table.tHead.rows[0].cells.length; t++) { var th = $(table.tHead.rows[0].cells[t]); var thText = th.html().replace(ascChar, "").replace(descChar, ""); if (t == iCol) { th.css("background-color", "#ccc"); } else { th.css("background-color", "#fff"); th.html(thText); } } var tbody = table.tBodies[0]; var colRows = tbody.rows; var aTrs = new Array; //将得到的行放入数组,备用 for (var i = 0; i < colRows.length; i++) { //注:如果要求“分组明细不参与排序”,把下面的注释去掉即可 //if ($(colRows[i]).attr("group") != undefined) { aTrs.push(colRows[i]); //} } //判断上一次排列的列和现在需要排列的是否同一个。 var thCol = $(table.tHead.rows[0].cells[iCol]); if (table.sortCol == iCol) { aTrs.reverse(); } else { //如果不是同一列,使用数组的sort方法,传进排序函数 aTrs.sort(compareEle(iCol, dataType)); } var oFragment = document.createDocumentFragment(); for (var i = 0; i = 0 ; t--) { var parent = $("#" + tableId + " tr[group='" + $(subRows[t]).attr("parent") + "']"); parent.after($(subRows[t])); } } //将列的类型转化成相应的可以排列的数据类型 function convert(sValue, dataType) { switch (dataType) { case "int": return parseInt(sValue, 10); case "float": return parseFloat(sValue); case "date": return new Date(Date.parse(sValue)); case "string": default: return sValue.toString(); } } //排序函数,iCol表示列索引,dataType表示该列的数据类型 function compareEle(iCol, dataType) { return function (oTR1, oTR2) { var vValue1 = convert(removeHtmlTag($(oTR1.cells[iCol]).html()), dataType); var vValue2 = convert(removeHtmlTag($(oTR2.cells[iCol]).html()), dataType); if (vValue1 < vValue2) { return -1; } else { return 1; } }; } //去掉html标签 function removeHtmlTag(html) { return html.replace(/]+>/g, ""); } //jQuery加载完以后,分组行高亮背景,分组明细隐藏 $(document).ready(function () { $("tr[group]").css("background-color", "#ff9"); $("tr[parent]").hide(); }); //点击分组行时,切换分组明细的显示/隐藏 function showSub(a) { var groupValue = $(a).parent().parent().attr("group"); var subDetails = $("tr[parent='" + groupValue + "']"); subDetails.toggle(); }
序号 | 姓名 | 生日 | 年龄 | 工资 |
---|---|---|---|---|
1 | Group-A | 01/12/1982 | 25 | 1000.50 |
2 | A-01 | 01/09/1982 | 25 | 2000.10 |
3 | A-02 | 01/10/1982 | 26 | 2000.20 |
4 | Group-B | 10/14/1999 | 18 | 1000.20 |
5 | B-01 | 02/12/1982 | 19 | 3000.20 |
6 | B-02 | 03/12/1982 | 20 | 3000.30 |
7 | Group-C | 10/14/1980 | 8 | 1000.30 |
8 | C-01 | 03/12/1981 | 17 | 3100.30 |
登录后复制
相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!
推荐阅读:
jQuery仿支付宝首页焦点图效果
JS点击小图片关联显示大图片
以上就是实现带分组数据Table表头排序功能的详细内容,更多请关注【创想鸟】其它相关文章!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。