本文实例讲述了jQuery实现的表格前端排序功能。分享给大家供大家参考,具体如下:
表格前端按列排序
依赖jQuery(本例使用jQuery-1.8.2)
1.初始化方法
(function($){ //插件 $.extend($,{ //命名空间 sortTable:{ sort:function(tableId,Idx){ var table = document.getElementById(tableId); var tbody = table.tBodies[0]; var tr = tbody.rows; var trValue = new Array(); for (var i=0; i<tr.length; i++ ) { trValue[i] = tr[i]; //将表格中各行的信息存储在新建的数组中 } if (tbody.sortCol == Idx) { trValue.reverse(); //如果该列已经进行排序过了,则直接对其反序排列 } else { trValue.sort(function(tr1, tr2){ var value1 = tr1.cells[Idx].innerText; //列 var value2 = tr2.cells[Idx].innerText; //第二列 value1 = value1.replace("%",""); //把有%的取消掉 value1=value1.trim(); //去空格 console.log(typeof(value1)); if(isNaN(value1)){ var index1 = value1.indexOf("分"); var index2 = value2.indexOf("分"); if(index1>0){ var num1 =value1.substring(0,index1); var num2 =value1.substring(index1+1,value1.length-1); var num3 =value2.substring(0,index2); var num4 =value2.substring(index2+1,value2.length-1); if(parseFloat(num1)>parseFloat(num3)){ return 1; } if(parseFloat(num1)<parseFloat(num3)){ return -1; } if(parseFloat(num1)==parseFloat(num3)){ return parseFloat(num2)-parseFloat(num4) } }else{ var a = tr1.cells[Idx].textContent; var b= tr2.cells[Idx].textContent; return a.localeCompare(b); } }else{ return parseFloat(value1)-parseFloat(value2); } }); } var fragment = document.createDocumentFragment(); //新建一个代码片段,用于保存排序后的结果 //var index = 0; var arrtotal =new Array(); for (var i=0; i<trValue.length; i++ ) { var c = trValue[i].cells[0].innerHTML; //console.log(c); if(c.trim().indexOf("汇总")!=-1){//汇总行总是排在表格最上面 // index = i; arrtotal.push(i); }else{ fragment.appendChild(trValue[i]); } } if(arrtotal.length>0){ for(var k=arrtotal.length; k<0; k-- ){ tbody.appendChild(trValue[arrtotal[k]]); } } //tbody.appendChild(trValue[index]); tbody.appendChild(fragment); //将排序的结果替换掉之前的值 tbody.sortCol = Idx; } } }); })(jQuery);
2.页面函数
function desc_change(id,str){ $("#desc_1").html("日期"); $("#desc_2").html("ID"); $("#desc_3").html("类别"); $("#"+id).html(str); } function desc(id,str){ var htmlstr =$("#"+id).text().trim(); var c =str; if(htmlstr==str){ c=str+'↓'; $("#"+id).html(c); }else if(htmlstr==str+'↓'){ c=str+'↑' $("#"+id).html(c); }else if(htmlstr==str+'↑'){ c=str+'↓' $("#"+id).html(c); } desc_change(id,c) }
3.DOM结构
<table id="tableSort"> <thead> <tr> <th onclick="$.sortTable.sort('tableSort',0);desc('desc_1','日期')" ><a id="desc_1" >日期</a></th> <th onclick="$.sortTable.sort('tableSort',1);desc('desc_2','软件ID')" ><a id="desc_2" >ID</a></th> <th onclick="$.sortTable.sort('tableSort',2);desc('desc_x','渠道ID')" ><a id="desc_3" >类别</a></th> </tr> </thead> <tbody> <tr> <td>201870601</td> <td>汇总</td> <td>新闻</td> </tr> </tbody> </table>
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery表格(table)操作技巧汇总》、《jQuery切换特效与技巧总结》、《jQuery扩展技巧总结》、《jQuery常用插件及用法总结》、《jQuery常见经典特效汇总》及《jquery选择器用法总结》
希望本文所述对大家jQuery程序设计有所帮助。
本文向大家介绍Python实现EXCEL表格的排序功能示例,包括了Python实现EXCEL表格的排序功能示例的使用技巧和注意事项,需要的朋友参考一下 EXCEL的数值排序功能还是挺强大的,升序、降序,尤其自定义排序,能够对多个字段进行排序工作。 那么,在Python大法中,有没有这样强大的排序功能呢?答案是有的,而且本人觉得Python的排序功能,一点不比EXCEL的差。 同样,我们依然用到的是
本文向大家介绍jquery实现的table排序功能示例,包括了jquery实现的table排序功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jquery实现的table排序功能。分享给大家供大家参考,具体如下: 运行效果图如下: 更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery表格(table)操作技巧汇总》、《jQuery切换特效与技巧总结》、《jQuer
本文向大家介绍JS简单实现表格排序功能示例,包括了JS简单实现表格排序功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JS简单实现表格排序功能的方法。分享给大家供大家参考,具体如下: 思路:遍历每个li,并把它们存放到数组中去,然后通过sort()方法进行排序,再插入 更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript操作DOM技巧总结》、《Ja
本文向大家介绍JS实现HTML表格排序功能,包括了JS实现HTML表格排序功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了JavaScript实现HTML表格排序功能,供大家参考,具体内容如下 HTML代码: JavaScirpt代码: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍基于jQuery实现表格的排序,包括了基于jQuery实现表格的排序的使用技巧和注意事项,需要的朋友参考一下 主要思路: 因为JS有SORT的方法,对数组进行排序,那么通过个方法,我们就会想到数组了。 1.点标表格标头的时候,取出点击的是那一列。即列的索引值。因为下面要进行排序的就是该列。所以我要知道是点的那一列。 2.对表格的数据部分,也就是tbody部分,进行点击的列
本文向大家介绍jQuery实现HTML表格单元格的合并功能,包括了jQuery实现HTML表格单元格的合并功能的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery实现HTML表格单元格合并的方法。分享给大家供大家参考,具体如下: 运行效果截图如下: 合并前: 合并后: 具体代码如下: 更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery表格(table)操作技巧汇