jQuery实现的表格前端排序功能示例


Posted in jQuery onSeptember 18, 2017

本文实例讲述了jQuery实现的表格前端排序功能。分享给大家供大家参考,具体如下:

表格前端按列排序

依赖jQuery(本例使用jQuery-1.8.2)

1.初始化方法

(function($){
  //插件
  $.extend($,{
    //命名空间
    sortTable:{
      sort:function(tableId,Idx){
        var table = document.getElementById(tableId);
        var tbody = table.tBodies[0];
        var tr = tbody.rows;
        var trValue = new Array();
        for (var i=0; i<tr.length; i++ ) {
          trValue[i] = tr[i]; //将表格中各行的信息存储在新建的数组中
        }
        if (tbody.sortCol == Idx) {
          trValue.reverse(); //如果该列已经进行排序过了,则直接对其反序排列
        } else {
          trValue.sort(function(tr1, tr2){
            var value1 = tr1.cells[Idx].innerText; //列
            var value2 = tr2.cells[Idx].innerText; //第二列
            value1 = value1.replace("%",""); //把有%的取消掉
            value1=value1.trim(); //去空格
            console.log(typeof(value1));
            if(isNaN(value1)){
              var index1 = value1.indexOf("分");
              var index2 = value2.indexOf("分");
              if(index1>0){
                var num1 =value1.substring(0,index1);
                var num2 =value1.substring(index1+1,value1.length-1);
                var num3 =value2.substring(0,index2);
                var num4 =value2.substring(index2+1,value2.length-1);
                if(parseFloat(num1)>parseFloat(num3)){
                  return 1;
                }
                if(parseFloat(num1)<parseFloat(num3)){
                  return -1;
                }
                if(parseFloat(num1)==parseFloat(num3)){
                  return parseFloat(num2)-parseFloat(num4)
                }
              }else{
                var a = tr1.cells[Idx].textContent;
                var b= tr2.cells[Idx].textContent;
                return a.localeCompare(b);
              }
            }else{
              return parseFloat(value1)-parseFloat(value2);
            }
          });
        }
        var fragment = document.createDocumentFragment(); //新建一个代码片段,用于保存排序后的结果
        //var index = 0;
        var arrtotal =new Array();
        for (var i=0; i<trValue.length; i++ ) {
          var c = trValue[i].cells[0].innerHTML;
          //console.log(c);
          if(c.trim().indexOf("汇总")!=-1){//汇总行总是排在表格最上面
          // index = i;
            arrtotal.push(i);
            }else{
          fragment.appendChild(trValue[i]);
         }
        }
        if(arrtotal.length>0){
          for(var k=arrtotal.length; k<0; k-- ){
             tbody.appendChild(trValue[arrtotal[k]]);
          }
        }
        //tbody.appendChild(trValue[index]);
        tbody.appendChild(fragment); //将排序的结果替换掉之前的值
        tbody.sortCol = Idx;
      }
    }
  });
})(jQuery);

2.页面函数

function desc_change(id,str){
   $("#desc_1").html("日期");
   $("#desc_2").html("ID");
   $("#desc_3").html("类别");
   $("#"+id).html(str);
}
function desc(id,str){
  var htmlstr =$("#"+id).text().trim();
  var c =str;
  if(htmlstr==str){
    c=str+'↓';
    $("#"+id).html(c);
  }else if(htmlstr==str+'↓'){
    c=str+'↑'
    $("#"+id).html(c);
  }else if(htmlstr==str+'↑'){
    c=str+'↓'
    $("#"+id).html(c);
  }
  desc_change(id,c)
}

3.DOM结构

<table id="tableSort">
    <thead>
    <tr>
        <th onclick="$.sortTable.sort('tableSort',0);desc('desc_1','日期')" ><a id="desc_1" >日期</a></th>
        <th onclick="$.sortTable.sort('tableSort',1);desc('desc_2','软件ID')" ><a id="desc_2" >ID</a></th>
      <th onclick="$.sortTable.sort('tableSort',2);desc('desc_x','渠道ID')" ><a id="desc_3" >类别</a></th>
    </tr>
    </thead>
    <tbody>
     <tr>
        <td>201870601</td>
        <td>汇总</td>
        <td>新闻</td>
     </tr>
    </tbody>
</table>

希望本文所述对大家jQuery程序设计有所帮助。

jQuery 相关文章推荐
jQuery EasyUI之验证框validatebox实例详解
Apr 10 jQuery
运用jQuery写的验证表单(实例讲解)
Jul 06 jQuery
jquery实现下拉菜单的手风琴效果
Jul 23 jQuery
jQuery实现所有验证通过方可提交的表单验证
Nov 21 jQuery
jQuery图片查看插件Magnify开发详解
Dec 25 jQuery
jQuery实现手机号正则验证输入及自动填充空格功能
Jan 02 jQuery
jQuery+CSS实现的标签页效果示例【测试可用】
Aug 14 jQuery
jQuery实现的鼠标拖动浮层功能示例【拖动div等任何标签】
Dec 29 jQuery
jQuery实现合并表格单元格中相同行操作示例
Jan 28 jQuery
解决JQuery的ajax函数执行失败alert函数弹框一闪而过问题
Apr 10 jQuery
jQuery实现动态生成年月日级联下拉列表示例
May 11 jQuery
JavaScript前端页面搜索功能案例【基于jQuery】
Jul 10 jQuery
jQuery实现对网页节点的增删改查功能示例
Sep 18 #jQuery
jQuery UI 实例讲解 - 日期选择器(Datepicker)
Sep 18 #jQuery
jQuery实现火车票买票城市选择切换功能
Sep 15 #jQuery
jQuery获取复选框选中的当前行的某个字段的值
Sep 15 #jQuery
jQuery plugin animsition使用小结
Sep 14 #jQuery
jquery 键盘事件的使用方法详解
Sep 13 #jQuery
React中jquery引用的实现方法
Sep 12 #jQuery
You might like
php下通过curl抓取yahoo boss 搜索结果的实现代码
2011/06/10 PHP
CI分页类首页、尾页不显示的解决方法
2016/03/28 PHP
centos+php+coreseek+sphinx+mysql之一coreseek安装篇
2016/10/25 PHP
PHP简单实现图片格式转换(jpg转png,gif转png等)
2019/10/30 PHP
Java 正则表达式学习总结和一些小例子
2012/09/13 Javascript
javascript中拼接HTML字符串的最快、最好的方法
2014/06/07 Javascript
javascript 闭包详解
2015/02/15 Javascript
JS实现滑动菜单效果代码(包括Tab,选项卡,横向等效果)
2015/09/24 Javascript
Bootstrap Chart组件使用教程
2016/04/28 Javascript
canvas学习之API整理笔记(二)
2016/12/29 Javascript
node.js入门教程之querystring模块的使用方法
2017/02/27 Javascript
jQuery Validate 校验多个相同name的方法
2017/05/18 jQuery
浅谈ES6新增的数组方法和对象
2017/08/08 Javascript
Electron-vue脚手架改造vue项目的方法
2018/10/22 Javascript
微信小程序当前时间时段选择器插件使用方法详解
2018/12/28 Javascript
laravel实现中文和英语互相切换的例子
2019/09/30 Javascript
JavaScript实现图片合成下载的示例
2020/11/19 Javascript
Python素数检测实例分析
2015/06/15 Python
微信 用脚本查看是否被微信好友删除
2016/10/28 Python
对numpy中数组元素的统一赋值实例
2018/04/04 Python
利用Django-environ如何区分不同环境
2018/08/26 Python
python利用JMeter测试Tornado的多线程
2020/01/12 Python
将pytorch转成longtensor的简单方法
2020/02/18 Python
2013年办公室秘书的个人自我鉴定
2013/10/24 职场文书
学生就业推荐信
2013/11/13 职场文书
yy生日主持词
2014/03/20 职场文书
节能宣传周活动总结
2014/05/08 职场文书
绿色环保演讲稿
2014/05/10 职场文书
竞选班干部演讲稿100字
2014/08/20 职场文书
个人四风问题整改措施思想汇报
2014/10/04 职场文书
简单的离婚协议书范本
2014/11/16 职场文书
先进教师事迹材料
2014/12/16 职场文书
2014公司年终工作总结
2014/12/19 职场文书
2015年清明节网上祭英烈留言寄语
2015/03/04 职场文书
高三毕业感言
2015/07/30 职场文书
上班旷工检讨书
2015/08/15 职场文书