基于jQuery实现表格的排序

 更新时间:2016年12月02日 11:14:19   作者:船长op  
本篇文章介绍了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实现返回顶部效果的方法

    jQuery实现返回顶部效果的方法

    这篇文章主要介绍了jQuery实现返回顶部效果的方法,涉及jQuery页面样式、鼠标事件及页面元素的相关操作技巧,需要的朋友可以参考下
    2015-05-05
  • jquery实现聚光灯效果的方法

    jquery实现聚光灯效果的方法

    这篇文章主要介绍了jquery实现聚光灯效果的方法,可实现鼠标滑过图片时显示当前图片高亮,其他图片变暗的聚光灯效果,非常具有实用价值,需要的朋友可以参考下
    2015-02-02
  • jQuery基础学习技巧总结

    jQuery基础学习技巧总结

    jQuery基础学习技巧总结...
    2007-06-06
  • jQuery子窗体取得父窗体元素的方法

    jQuery子窗体取得父窗体元素的方法

    这篇文章主要介绍了jQuery子窗体取得父窗体元素的方法,涉及jQuery窗体元素操作的相关技巧,非常具有实用价值,需要的朋友可以参考下
    2015-05-05
  • 绑定回车enter事件代码

    绑定回车enter事件代码

    这篇文章主要介绍了绑定回车enter事件代码,需要的朋友可以参考下
    2014-05-05
  • jQuery+ajax实现滚动到页面底部自动加载图文列表效果(类似图片懒加载)

    jQuery+ajax实现滚动到页面底部自动加载图文列表效果(类似图片懒加载)

    这篇文章主要介绍了jQuery+ajax实现滚动到页面底部自动加载图文列表效果,模拟图片懒加载功能,涉及jQuery的ajax与asp.net交互动态显示页面内容的相关技巧,需要的朋友可以参考下
    2016-06-06
  • jQuery实现图片跟随效果

    jQuery实现图片跟随效果

    这篇文章主要为大家详细介绍了jQuery实现图片跟随效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • jQuery中animate的几种用法与注意事项

    jQuery中animate的几种用法与注意事项

    在今天之前,我对jQuery的中的animate()方法还停留在最常见的用法,查了一下手册,发现在1.8的时候增加了几个比较有用的回调函数,想着就来总结下jQuery中animate的几种用法与注意事项,方便自己或者大家有需要的时候参考借鉴,下面来一起看看吧。
    2016-12-12
  • jQuery获取样式中颜色值的方法

    jQuery获取样式中颜色值的方法

    这篇文章主要介绍了jQuery获取样式中颜色值的方法,可实现针对IE与Chrome、Firefox等不同浏览器都可获取css样式中background-color值的功能,非常具有实用价值,需要的朋友可以参考下
    2015-01-01
  • 详细解读Jquery各Ajax函数($.get(),$.post(),$.ajax(),$.getJSON())

    详细解读Jquery各Ajax函数($.get(),$.post(),$.ajax(),$.getJSON())

    这篇文章主要介绍了详细解读Jquery各Ajax函数($.get(),$.post(),$.ajax(),$.getJSON())的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08

最新评论