基于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 相关文章推荐
JQuery获取或设置ckeditor的数据(示例代码)
Nov 15 Javascript
javascript生成随机数的方法
May 16 Javascript
JQuery实现table行折叠效果以JSON做数据源
May 26 Javascript
jQuery中:visible选择器用法实例
Dec 30 Javascript
JSON格式的键盘编码对照表
Jan 29 Javascript
JavaScript中constructor()方法的使用简介
Jun 05 Javascript
jQuery+HTML5实现图片上传前预览效果
Aug 20 Javascript
JavaScript如何动态创建table表格
Aug 02 Javascript
利用浮层使select不可选的实现方法
Dec 03 Javascript
判断滚动条滑到底部触发事件(实例讲解)
Nov 15 Javascript
layui 数据表格+分页+搜索+checkbox+缓存选中项数据的方法
Sep 21 Javascript
vue 解决uglifyjs-webpack-plugin打包出现报错的问题
Aug 04 Javascript
利用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
详细介绍PHP应用提速面面观
2006/10/09 PHP
php htmlentities和htmlspecialchars 的区别
2008/08/18 PHP
PHP获取数组最大值下标的方法
2015/05/12 PHP
浅析PHP数据导出知识点
2018/02/17 PHP
jQuery Validation插件remote验证方式的Bug解决
2010/07/01 Javascript
统计jQuery中各字符串出现次数的工具
2012/05/03 Javascript
根据表格中的某一列进行排序的javascript代码
2013/11/29 Javascript
浅析jQuery1.8的几个小变化
2013/12/10 Javascript
JavaScript中的条件判断语句使用详解
2015/06/03 Javascript
javascript框架设计之类工厂
2015/06/23 Javascript
vue-router路由懒加载的实现(解决vue项目首次加载慢)
2018/08/28 Javascript
详解vue-cli3多页应用改造
2019/06/04 Javascript
微信小程序如何使用globalData的方法
2019/06/06 Javascript
vue父组件给子组件的组件传值provide inject的方法
2019/10/23 Javascript
jQuery使用hide()、toggle()函数实现相机品牌展示隐藏功能
2021/01/29 jQuery
python实现根据用户输入从电影网站获取影片信息的方法
2015/04/07 Python
python在指定目录下查找gif文件的方法
2015/05/04 Python
Python re 模块findall() 函数返回值展现方式解析
2019/08/09 Python
科沃斯机器人官网商城:Ecovacs
2016/08/29 全球购物
法国时尚品牌乐都特瑞士站:La Redoute瑞士
2016/09/05 全球购物
Pure Collection美国官网:来自英国羊绒专家的奢华羊绒
2017/11/19 全球购物
美国受信赖的教育产品供应商:Nest Learning
2018/06/14 全球购物
美国修容界大佬创建的个人美妆品牌:Kevyn Aucoin Beauty
2018/12/12 全球购物
Ootori在线按摩椅店:一家专业的按摩椅制造商
2019/04/10 全球购物
Ego Shoes官网:英国时髦鞋类品牌
2020/10/19 全球购物
酒店经理职责
2014/01/30 职场文书
英文推荐信格式范文
2014/05/09 职场文书
项目委托协议书(最新)
2014/09/13 职场文书
党的群众路线教育实践活动制度建设计划方案
2014/10/31 职场文书
确保减税降费落地生根,用实实在在措施
2019/07/19 职场文书
导游词之寿县报恩寺
2020/01/19 职场文书
Python中常见的反爬机制及其破解方法总结
2021/06/10 Python
Django REST framework 限流功能的使用
2021/06/24 Python
详解MySQL中timestamp和datetime时区问题导致做DTS遇到的坑
2021/12/06 MySQL
Django框架模板用法详解
2022/06/10 Python
Go gRPC进阶教程gRPC转换HTTP
2022/06/16 Golang