首页 > 语言 > JavaScript > 正文

jQuery实现的表格前端排序功能示例

2024-05-06 15:26:36
字体:
来源:转载
供稿:网友

本文实例讲述了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.页面函数

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选