国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > JavaScript > 正文

jQuery實(shí)現(xiàn)的表格前端排序功能示例

2019-11-19 15:24:51
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

本文實(shí)例講述了jQuery實(shí)現(xiàn)的表格前端排序功能。分享給大家供大家參考,具體如下:

表格前端按列排序

依賴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]; //將表格中各行的信息存儲(chǔ)在新建的數(shù)組中        }        if (tbody.sortCol == Idx) {          trValue.reverse(); //如果該列已經(jīng)進(jìn)行排序過(guò)了,則直接對(duì)其反序排列        } 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(); //新建一個(gè)代碼片段,用于保存排序后的結(jié)果        //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); //將排序的結(jié)果替換掉之前的值        tbody.sortCol = Idx;      }    }  });})(jQuery);

2.頁(yè)面函數(shù)

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結(jié)構(gòu)

<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>

更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery表格(table)操作技巧匯總》、《jQuery切換特效與技巧總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》、《jQuery常用插件及用法總結(jié)》、《jQuery常見(jiàn)經(jīng)典特效匯總》及《jquery選擇器用法總結(jié)

希望本文所述對(duì)大家jQuery程序設(shè)計(jì)有所幫助。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 新兴县| 洛隆县| 同德县| 浦北县| 色达县| 舟山市| 海城市| 沧州市| 调兵山市| 福建省| 罗江县| 濮阳县| 彰武县| 海南省| 康乐县| 吴桥县| 宜昌市| 丁青县| 绥中县| 辰溪县| 庆元县| 长垣县| 香港| 定南县| 渝中区| 怀远县| 萍乡市| 平塘县| 六安市| 黄大仙区| 册亨县| 望谟县| 邻水| 高阳县| 忻州市| 山阴县| 江都市| 施秉县| 洞口县| 扶风县| 鸡泽县|