jQuery實(shí)現(xiàn)的表格前端排序功能示例
本文實(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ì)有所幫助。
- jQuery表格排序組件-tablesorter使用示例
- 基于jquery的表格排序
- Jquery 選中表格一列并對(duì)表格排序?qū)崿F(xiàn)原理
- jquery tablesorter.js 支持中文表格排序改進(jìn)
- jQuery+Ajax實(shí)現(xiàn)表格數(shù)據(jù)不同列標(biāo)題排序(為表格注入活力)
- jquery 表格排序、實(shí)時(shí)搜索表格內(nèi)容(附圖)
- 擴(kuò)展jquery實(shí)現(xiàn)客戶端表格的分頁(yè)、排序功能代碼
- jquery實(shí)現(xiàn)表格本地排序的方法
- jquery.tableSort.js表格排序插件使用方法詳解
- 基于jQuery實(shí)現(xiàn)表格的排序
- jQuery增加和刪除表格項(xiàng)目及實(shí)現(xiàn)表格項(xiàng)目排序的方法
- jQuery html表格排序插件tablesorter使用方法詳解
相關(guān)文章
jquery中event對(duì)象屬性與方法小結(jié)
本篇文章主要是對(duì)jquery中的event對(duì)象屬性與方法進(jìn)行了詳細(xì)的總結(jié)介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-12-12
Jquery實(shí)現(xiàn)的簡(jiǎn)單輪播效果【附實(shí)例】
下面小編就為大家?guī)?lái)一篇Jquery實(shí)現(xiàn)的簡(jiǎn)單輪播效果【附實(shí)例】。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考2016-04-04
基于jQuery中ajax的相關(guān)方法匯總(必看篇)
下面小編就為大家?guī)?lái)一篇基于基于jQuery中ajax的相關(guān)方法匯總。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11
分析了一下JQuery中的extend方法實(shí)現(xiàn)原理
這篇文章主要介紹了通過(guò)jQuery.extend的源碼分析了一下JQuery中的extend方法實(shí)現(xiàn)原理以及使用方式,非常的詳細(xì),這里推薦給大家,有需要的小伙伴來(lái)參考下吧。2015-02-02
使用jQuery ajaxupload插件實(shí)現(xiàn)無(wú)刷新上傳文件
項(xiàng)目中會(huì)經(jīng)常用到AJAX無(wú)刷新上傳圖片,但是iframe上傳和flash插件都是比較復(fù)雜的,所以就找了一個(gè)jquery的插件。下面通過(guò)實(shí)例代碼給大家介紹使用jQuery ajaxupload插件實(shí)現(xiàn)無(wú)刷新上傳文件功能,需要的朋友參考下吧2017-04-04
基于jquery實(shí)現(xiàn)滾輪放大縮小圖片的函數(shù)代碼
這篇文章主要介紹了基于jquery實(shí)現(xiàn)滾輪放大縮小圖片的函數(shù)代碼,需要的朋友可以參考下2023-05-05
jQuery中校驗(yàn)時(shí)間格式的正則表達(dá)式小結(jié)
下面我介紹兩種校驗(yàn)時(shí)間格式的正則表達(dá)式實(shí)例了,這個(gè)其實(shí)可以直接叫js了,因?yàn)檎齽t功能jquery與js是一樣的,下面看實(shí)例2013-09-09

