基于jQuery实现表格的排序


Posted in Javascript onDecember 02, 2016
$(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的最后去.(最先插入的,将是在第一行。)

以上就是本文的全部内容,希望对大家有所帮助,谢谢对三水点靠木的支持!

Javascript 相关文章推荐
HTTP状态代码以及定义(解释)
Feb 02 Javascript
json格式化/压缩工具 Chrome插件扩展版
May 25 Javascript
理解Javascript_08_函数对象
Oct 15 Javascript
用box固定长宽实现图片自动轮播js代码
Jun 09 Javascript
js实现编辑div节点名称的方法
Dec 17 Javascript
Javascript进制转换实例分析
May 14 Javascript
jQuery+ajax实现文章点赞功能的方法
Dec 31 Javascript
微信分享调用jssdk实例
Jun 08 Javascript
你应该知道的几类npm依赖包管理详解
Oct 06 Javascript
vue 列表页跳转详情页获取id以及详情页通过id获取数据
Mar 27 Javascript
Vue环境搭建+VSCode+Win10的详细教程
Aug 19 Javascript
vue首次渲染全过程
Apr 21 Vue.js
利用jQuery插件imgAreaSelect实现图片上传裁剪(放大缩小)
Dec 02 #Javascript
关于Vue.js一些问题和思考学习笔记(1)
Dec 02 #Javascript
利用jQuery来动态为属性添加或者删除属性的简单方法
Dec 02 #Javascript
基于javascript实现的快速排序
Dec 02 #Javascript
微信公众平台开发教程(五)详解自定义菜单
Dec 02 #Javascript
基于jQuery实现滚动切换效果
Dec 02 #Javascript
遍历json 对象的属性并且动态添加属性的实现
Dec 02 #Javascript
You might like
Adodb的十个实例(清晰版)
2006/12/31 PHP
php中$_REQUEST、$_POST、$_GET的区别和联系小结
2011/11/23 PHP
php网页版聊天软件实现代码
2016/08/12 PHP
使用PHP连接数据库_实现用户数据的增删改查的整体操作示例
2017/09/01 PHP
laravel 获取某个查询的查询SQL语句方法
2019/10/12 PHP
判断页面是关闭还是刷新的js代码
2007/01/28 Javascript
用jscript启动sqlserver
2007/06/21 Javascript
基于jquery用于查询操作的实现代码
2010/05/10 Javascript
JavaScript接口实现代码 (Interfaces In JavaScript)
2010/06/11 Javascript
js读写json文件实例代码
2014/10/21 Javascript
javascript使用prototype完成单继承
2014/12/24 Javascript
firefox浏览器用jquery.uploadify插件上传时报HTTP 302错误
2015/03/01 Javascript
Bootstrap模态框(modal)垂直居中的实例代码
2016/08/18 Javascript
javascript数组遍历的方法实例分析
2016/09/13 Javascript
浅谈JS使用[ ]来访问对象属性
2016/09/21 Javascript
Bootstrap Table从服务器加载数据进行显示的实现方法
2016/09/29 Javascript
关于vuex的学习实践笔记
2017/04/05 Javascript
详解使用VUE搭建后台管理系统(vue-cli更新至3.0)
2018/08/22 Javascript
Vue 组件参数校验与非props特性的方法
2019/02/12 Javascript
swiper实现异形轮播效果
2019/11/28 Javascript
javascript实现前端分页效果
2020/06/24 Javascript
token 机制和实现方式
2020/12/15 Javascript
[39:11]DOTA2上海特级锦标赛C组资格赛#2 LGD VS Newbee第二局
2016/02/28 DOTA
零基础学Python(一)Python环境安装
2014/08/20 Python
python基于phantomjs实现导入图片
2016/05/13 Python
Python3分析处理声音数据的例子
2019/08/27 Python
python实现淘宝购物系统
2019/10/25 Python
Python自动化xpath实现自动抢票抢货
2020/09/19 Python
CSS3 按钮边框动画的实现
2020/11/12 HTML / CSS
JDBC操作数据库的基本流程是什么
2014/10/28 面试题
中国央视网签名寄语
2014/01/18 职场文书
2014年党的群众路线教育实践活动总结
2014/04/25 职场文书
电子商务专业应届毕业生求职信
2014/06/21 职场文书
手机销售员岗位职责
2015/04/11 职场文书
未来,这5大方向都很适合创业
2019/07/22 职场文书
详解PyTorch模型保存与加载
2022/04/28 Python