基于jQuery实现表格的排序
$(function(){
//存入点击列的每一个TD的内容;
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));
}
});
}
}
//比较函数的参数函数
var compare_down = function(a,b){
return a-b;
}
var compare_up = function(a,b){
return b-a;
}
//比较函数
var fSort = function(compare){
aTdCont.sort(compare);
}
//取出TD的值,并存入数组,取出前二个TD值;
var fSetTdCont = function(thIndex){
$("tbody tr").each(function() {
var tdCont = $(this).children("td:eq("+thIndex+")").text();
aTdCont.push(tdCont);
});
}
//点击时需要执行的函数
var clickFun = function(thindex){
aTdCont = [];
//获取点击当前列的索引值
var nThCount = thindex;
//调用sortTh函数 取出要比较的数据
fSetTdCont(nThCount);
}
//点击事件绑定函数
$("th").toggle(function(){
thi= $(this).index();
clickFun(thi);
//调用比较函数,降序
fSort(compare_up);
//重新排序行
setTrIndex(thi);
},function(){
clickFun(thi);
//调用比较函数 升序
fSort(compare_down);
//重新排序行
setTrIndex(thi);
})
})
主要思路:
因为JS有SORT的方法,对数组进行排序,那么通过个方法,我们就会想到数组了。
1.点标表格标头的时候,取出点击的是那一列。即列的索引值。因为下面要进行排序的就是该列。所以我要知道是点的那一列。
2.对表格的数据部分,也就是tbody部分,进行点击的列的取值,把这些值存入到一个数组当中。
3.将存入数据的数组,通过SORT方法进行排序。(这里写了两种,升,或降,因为是点击时要切换排序的方式。第一次降,第二次升,第三降,第四升,依次进行)
4.将排序好的数组的值进行遍历,在遍历过程中,和每一行TR的点击列的那个TD当中的数据进行一个比较。如果相等,就插入到tbody的最后去.(最先插入的,将是在第一行。)
以上就是本文的全部内容,希望对大家有所帮助,谢谢对脚本之家的支持!
- jQuery表格排序组件-tablesorter使用示例
- 基于jquery的表格排序
- Jquery 选中表格一列并对表格排序实现原理
- jquery tablesorter.js 支持中文表格排序改进
- jQuery+Ajax实现表格数据不同列标题排序(为表格注入活力)
- jquery 表格排序、实时搜索表格内容(附图)
- 扩展jquery实现客户端表格的分页、排序功能代码
- jquery实现表格本地排序的方法
- jquery.tableSort.js表格排序插件使用方法详解
- jQuery增加和删除表格项目及实现表格项目排序的方法
- jQuery html表格排序插件tablesorter使用方法详解
- jQuery实现的表格前端排序功能示例
相关文章
详解JavaScript中jQuery和Ajax以及JSONP的联合使用
这篇文章主要介绍了详解JavaScript中jQuery和Ajax以及JSONP的联合使用,jQuery库和Ajax异步结构以及JSON数据传输也是JS日常编程中最常用到的东西,需要的朋友可以参考下2015-08-08
jQuery EasyUI基础教程之EasyUI常用组件(推荐)
这篇文章主要介绍了jQuery EasyUI基础教程之EasyUI常用组件(推荐),非常不错,具有参考借鉴价值,需要的朋友可以参考下2016-07-07
jquery操作checked属性以及disabled属性的多种方法
这篇文章主要介绍了jquery控制checked属性以及disabled属性的多种方法,下面只提到checked,其实disabled在jquery里的用法和checked是一模一样的,需要的朋友可以参考下2014-06-06


最新评论