全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

本文实例讲述了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表格(table)操作技巧汇总》、《jQuery切换特效与技巧总结》、《jQuery扩展技巧总结》、《jQuery常用插件及用法总结》、《jQuery常见经典特效汇总》及《jquery选择器用法总结》

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


# jQuery  # 表格  # 排序  # jQuery表格排序组件-tablesorter使用示例  # 基于jquery的表格排序  # Jquery 选中表格一列并对表格排序实现原理  # jquery tablesorter.js 支持中文表格排序改进  # jQuery+Ajax实现表格数据不同列标题排序(为表格注入活力)  # jquery 表格排序、实时搜索表格内容(附图)  # 扩展jquery实现客户端表格的分页、排序功能代码  # jquery实现表格本地排序的方法  # jquery.tableSort.js表格排序插件使用方法详解  # 基于jQuery实现表格的排序  # jQuery增加和删除表格项目及实现表格项目排序的方法  # jQuery html表格排序插件tablesorter使用方法详解  # 相关内容  # 过了  # 感兴趣  # 对其  # 给大家  # 排在  # 更多关于  # 所述  # 程序设计  # 新建一个  # 组中  # 本例  # 操作技巧  # 选择器  # 讲述了  # 反序  # length  # lt  # td  # sortCol 


相关文章: 如何在IIS7中新建站点?详细步骤解析  如何快速搭建高效香港服务器网站?  北京网站制作网页,网站升级改版需要多久?  成都品牌网站制作公司,成都营业执照年报网上怎么办理?  如何高效利用200m空间完成建站?  建站之星后台密码遗忘如何找回?  深圳网站制作的公司有哪些,dido官方网站?  制作网站的过程怎么写,用凡科建站如何制作自己的网站?  如何在橙子建站中快速调整背景颜色?  官网网站制作腾讯审核要多久,联想路由器newifi官网  实现虚拟支付需哪些建站技术支撑?  建站之星安装提示数据库无法连接如何解决?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  PHP 500报错的快速解决方法  C#如何序列化对象为XML XmlSerializer用法  存储型VPS适合搭建中小型网站吗?  如何通过免费商城建站系统源码自定义网站主题与功能?  哈尔滨网站建设策划,哈尔滨电工证查询网站?  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?  如何自定义建站之星网站的导航菜单样式?  专业制作网站的公司哪家好,建立一个公司网站的费用.有哪些部分,分别要多少钱?  如何选择靠谱的建站公司加盟品牌?  如何零基础在云服务器搭建WordPress站点?  教学论文网站制作软件有哪些,写论文用什么软件 ?  简历在线制作网站免费,免费下载个人简历的网站是哪些?  如何快速完成中国万网建站详细流程?  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  如何实现建站之星域名转发设置?  全景视频制作网站有哪些,全景图怎么做成网页?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  完全自定义免费建站平台:主题模板在线生成一站式服务  如何快速搭建支持数据库操作的智能建站平台?  香港服务器网站生成指南:免费资源整合与高速稳定配置方案  如何获取开源自助建站系统免费下载链接?  个人网站制作流程图片大全,个人网站如何注销?  高性能网站服务器配置指南:安全稳定与高效建站核心方案  广德云建站网站建设方案与建站流程优化指南  如何配置WinSCP新建站点的密钥验证步骤?  专业的网站制作设计是什么,如何制作一个企业网站,建设网站的基本步骤有哪些?  宝塔面板如何快速创建新站点?  定制建站是什么?如何实现个性化需求?  建站之星2.7模板:企业网站建设与h5定制设计专题  学校为何禁止电信移动建设网站?  微信网站制作公司有哪些,民生银行办理公司开户怎么在微信网页上查询进度?  ,南京靠谱的征婚网站?  定制建站价位费用解析与套餐推荐全攻略  高防服务器租用如何选择配置与防御等级?  定制建站哪家更专业可靠?推荐榜单揭晓  孙琪峥织梦建站教程如何优化数据库安全? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。