基于jQuery實現(xiàn)表格的排序
$(function(){
//存入點擊列的每一個TD的內(nèi)容;
var aTdCont = [];
//點擊列的索引值
var thi = 0
//重新對TR進行排序
var setTrIndex = function(tdIndex){
for(i=0;i<aTdCont.length;i++){
var trCont = aTdCont[i];
$("tbody tr").each(function() {
var thisText = $(this).children("td:eq("+tdIndex+")").text();
if(thisText == trCont){
$("tbody").append($(this));
}
});
}
}
//比較函數(shù)的參數(shù)函數(shù)
var compare_down = function(a,b){
return a-b;
}
var compare_up = function(a,b){
return b-a;
}
//比較函數(shù)
var fSort = function(compare){
aTdCont.sort(compare);
}
//取出TD的值,并存入數(shù)組,取出前二個TD值;
var fSetTdCont = function(thIndex){
$("tbody tr").each(function() {
var tdCont = $(this).children("td:eq("+thIndex+")").text();
aTdCont.push(tdCont);
});
}
//點擊時需要執(zhí)行的函數(shù)
var clickFun = function(thindex){
aTdCont = [];
//獲取點擊當(dāng)前列的索引值
var nThCount = thindex;
//調(diào)用sortTh函數(shù) 取出要比較的數(shù)據(jù)
fSetTdCont(nThCount);
}
//點擊事件綁定函數(shù)
$("th").toggle(function(){
thi= $(this).index();
clickFun(thi);
//調(diào)用比較函數(shù),降序
fSort(compare_up);
//重新排序行
setTrIndex(thi);
},function(){
clickFun(thi);
//調(diào)用比較函數(shù) 升序
fSort(compare_down);
//重新排序行
setTrIndex(thi);
})
})
主要思路:
因為JS有SORT的方法,對數(shù)組進行排序,那么通過個方法,我們就會想到數(shù)組了。
1.點標(biāo)表格標(biāo)頭的時候,取出點擊的是那一列。即列的索引值。因為下面要進行排序的就是該列。所以我要知道是點的那一列。
2.對表格的數(shù)據(jù)部分,也就是tbody部分,進行點擊的列的取值,把這些值存入到一個數(shù)組當(dāng)中。
3.將存入數(shù)據(jù)的數(shù)組,通過SORT方法進行排序。(這里寫了兩種,升,或降,因為是點擊時要切換排序的方式。第一次降,第二次升,第三降,第四升,依次進行)
4.將排序好的數(shù)組的值進行遍歷,在遍歷過程中,和每一行TR的點擊列的那個TD當(dāng)中的數(shù)據(jù)進行一個比較。如果相等,就插入到tbody的最后去.(最先插入的,將是在第一行。)
以上就是本文的全部內(nèi)容,希望對大家有所幫助,謝謝對腳本之家的支持!
- jQuery表格排序組件-tablesorter使用示例
- 基于jquery的表格排序
- Jquery 選中表格一列并對表格排序?qū)崿F(xiàn)原理
- jquery tablesorter.js 支持中文表格排序改進
- jQuery+Ajax實現(xiàn)表格數(shù)據(jù)不同列標(biāo)題排序(為表格注入活力)
- jquery 表格排序、實時搜索表格內(nèi)容(附圖)
- 擴展jquery實現(xiàn)客戶端表格的分頁、排序功能代碼
- jquery實現(xiàn)表格本地排序的方法
- jquery.tableSort.js表格排序插件使用方法詳解
- jQuery增加和刪除表格項目及實現(xiàn)表格項目排序的方法
- jQuery html表格排序插件tablesorter使用方法詳解
- jQuery實現(xiàn)的表格前端排序功能示例
相關(guān)文章
詳解JavaScript中jQuery和Ajax以及JSONP的聯(lián)合使用
這篇文章主要介紹了詳解JavaScript中jQuery和Ajax以及JSONP的聯(lián)合使用,jQuery庫和Ajax異步結(jié)構(gòu)以及JSON數(shù)據(jù)傳輸也是JS日常編程中最常用到的東西,需要的朋友可以參考下2015-08-08
基于JQuery和DWR實現(xiàn)異步數(shù)據(jù)傳遞
這篇文章主要介紹了基于JQuery和DWR實現(xiàn)異步數(shù)據(jù)傳遞,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-10-10
jQuery EasyUI基礎(chǔ)教程之EasyUI常用組件(推薦)
這篇文章主要介紹了jQuery EasyUI基礎(chǔ)教程之EasyUI常用組件(推薦),非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-07-07
jquery操作checked屬性以及disabled屬性的多種方法
這篇文章主要介紹了jquery控制checked屬性以及disabled屬性的多種方法,下面只提到checked,其實disabled在jquery里的用法和checked是一模一樣的,需要的朋友可以參考下2014-06-06
JQuery fileupload插件實現(xiàn)文件上傳功能
這篇文章主要介紹了JQuery fileupload插件實現(xiàn)文件上傳功能的相關(guān)資料,需要的朋友可以參考下2016-03-03

