JS实现前台表格排序功能

虽然数据量不大的情况下,前台排序速度比较快,但一般情况下,我们的项目只使用后台排序,原因有二:

一是代码简单;二是前台JS排序对于有分页的情况无法处理。

前段时间,有个功能需要用到前台排序,没办法,写一个吧,下面记录一下实现的过程,其实很简单,如下:

var _sortType; //记录排序方向
 var _sortColumnIndex;//记录排序列位置
 var _sortMaxRow;//记录需要排序的行数
 
 /*
  *排序初始化
  */
 function initSort(obj){
  
  /*
   *计算需要排序的行数[此处取的是‘第一列不为空的行数’]
   *判断‘是否为空’时空格也要过滤掉
   */
  if(_sortMaxRow == null || _sortMaxRow == ''){
   var table1 = obj.parentNode.parentNode;
   var rows = table1.rows;
   for(var i = 1;i < rows.length;i++){
    var tv = rows[i].cells[0].innerText;
    if(tv != null && tv.replace(/(^\s*)(\s*$)/g,'') != ''){
     _sortMaxRow = i; 
    }
   }
  }
  
  /*
   *计算第几列需要排序
   */
  var sortColumnIndex = obj.cellIndex;
  
  /*
   *设置排序方向:
   *1、如果要排序列与上一次排序列位置相同,则将排序方向反转
   *2、如果要排序列与上一次排序列位置不相同,则排序方向不变,并设置需要排序的列位置
   */
  if(sortColumnIndex != _sortColumnIndex){
   _sortColumnIndex = sortColumnIndex;
   if(_sortType == null || _sortType == ''){
    _sortType = 'asc';
   }
  }
  else{
   if(_sortType == '' || _sortType == 'desc'){
    _sortType = 'asc';
   }
   else{
    _sortType = 'desc';
   }
  }
 }
 
 /*
  *执行排序
  */
 function execSort(obj){
  if(_sortColumnIndex == ''){
   sortField = 1;
  }
  if(_sortType == ''){
   sortType = 'asc';
  }
  
  /*
   *以下为排序部分
   *1、排序采用的是‘下沉法排序’[即,冒泡法的的逆方向]
   *2、由于涉及到隔行换色的问题,所以互换时只是把两行的内容互换,并没有将两个行对象互换
   */
  var table1 = obj.parentNode.parentNode; //通过TD获得TABLE
  for(var i = _sortMaxRow - 1;i >= 1;i--){
   for(j = 1;j <= i;j++){
    var t_first = table1.rows[j].cells[_sortColumnIndex].innerText;
    var t_second = table1.rows[j+1].cells[_sortColumnIndex].innerText;
    if((_sortType=='asc' && t_first > t_second) || (_sortType=='desc' && t_first < t_second)){
     swapRow(table1.rows[j],table1.rows[j+1]);
    }
   }
  }
 }
 
 function swapRow(row1,row2){
  for(var k = 0;k < row1.cells.length;k++){
   var tv = row1.cells[k].innerText;
   row1.cells[k].innerText = row2.cells[k].innerText;
   row2.cells[k].innerText = tv;
  }
 }

调用时,在表头TD上加 onclick="javascript:initSort(this);execSort(this);"

本文转载JS实现前台表格排序功能 - anywhere - 博客园 (cnblogs.com)

JS实现前台表格排序功能的更多相关文章

  1. js简单实现表格排序

    昨天看到一篇关于表格排序的随笔,鉴于本人还只会简单的js,不会使用封装,所以自己也试了一下写这个效果.可能不太优化,原理思路是:获取行对象tr,排序tr中要比较的对象td,排序后添加回tbody.如下 ...

  2. JS实现表格排序

    今天有点闲,写个小东西,使用JS实现点击表格标题栏实现自动排序功能,嘻嘻... 一.JS代码,文件名为code.js如下: (function($){ //插件 $.extend($,{ //命名空间 ...

  3. JS对表格排序(支持对序号,数字,字母,日期)

    JS对表格排序(支持对序号,数字,字母,日期) 前不久看到淘宝组件有"对表格排序的插件" 如想要看 可以看这个地址 http://gallery.kissyui.com/KSort ...

  4. 案例学习总结:原生JS实现表格排序

    最近在学习js的表格排序,没想到看不起眼的表格排序实际上却暗含了众多JS知识点.在这里记录一下此次学习过程.希望对大家也有所帮助. 完整的表格排序涉及了下列这些知识点: call方法使用 sort方法 ...

  5. js 实现table表格拖拽和点击表头升降序排序

    js 实现table表格拖拽和点击表头升降序排序,写的比较乱,用的时候可以把其中的一些模块函数提取出来 样式,由于是可拖拽表格,所以样式 table tr th{cursor:move;} js实现 ...

  6. [转载]EasyUI中数据表格DataGrid添加排序功能

    我们这里演示的是EasyUI数据表格DataGrid从服务器端排序功能,因为觉的本地数据排序没有多大的作用,一般我们DataGrid不会读取全部数据,只会读取当前页的数据,所以本地数据排序也只是对当前 ...

  7. JQuery Easyui/TopJUI 用JS创建数据表格并实现增删改查功能

    JQuery Easyui/TopJUI 用JS创建数据表格并实现增删改查功能 html <table id="productDg"></table> &l ...

  8. 前端 vue/react 或者 js 导入/导出 xlsx/xls (带样式)表格的功能

    第一种导出表格的功能: yarn add xlsx script-loader file-saver xlsx-style 效果展示 xlsx-style的bug修复:node_module/xlsx ...

  9. JS表格排序

    var employees = [] employees[0] = { name: "George", age: 32, retiredate: "March 12, 2 ...

随机推荐

  1. 10. linux 系统启动流程

    POST-->BIOS(Boot Sequence)-->MBR(bootloader,446)-->Kernel-->initrd-->(ROOTFS)/sbin/in ...

  2. 基于MATLAB的手写公式识别(转折)

    2021-03-29 21:11:00 很难说自己是不是上当受骗了,老师明明说利用MATLAB进行手写体(记得是手写体,再不济印刷体)的识别是轻而易举的. 平时我也十分喜欢MATLAB这一操作系统,认 ...

  3. linux下安装并使用msgfmt命令

    msgfmt安装方法: sudo apt-get install gettext 编码 po 文件为 mo 文件: msgfmt -o test.mo test.po mo 文件反编码成 po文件: ...

  4. hdu2846 字典树(带id的)

    题意:      给你一些模式串,然后给你一些提问,每个提问是给你一个串,问你这个串在上 面的模式串中出现的次数. 思路:       一开始想到hash,但是因为用的是map,所以超时了,map的操 ...

  5. LA3989女士的选择

    题意:       给你n个男士n个女士,然后给你每个男士中女士的排名,和每个女士中每个男士在他们心中的排名,问你是否可以组成稳定的舞伴,如果存在以下情况(1)男生u和女生v不是舞伴,他们喜欢对方的程 ...

  6. POJ1611基础带权并查集

    题意:       有一个人生病了,和他一个社团或者间接和他有联系的人都会生病,问一共有多少人生病了. 思路:       比较简单和基础的题,带权并查集中的一种,就是记录更新集合元素个数,这个题目我 ...

  7. 使用BurpSuite抓取HTTPS网站的数据包

    昨天面试,技术官问到了我如何使用BurpSuite抓取https网站的数据包,一时间没能回答上来(尴尬!).因为以前https网站的数据包我都是用Fiddler抓取的,Fiddlert自动帮我们配置好 ...

  8. Python爬虫之requests库的使用

    requests库 虽然Python的标准库中 urllib模块已经包含了平常我们使用的大多数功能,但是它的 API 使用起来让人感觉不太好,而 Requests宣传是 "HTTP for ...

  9. Jenkins + Docker + ASP.NET Core自动化部署

    本来没想着要写这篇博客,但是在实操过程中,一个是被网络问题搞炸了心态(真心感觉网络能把人搞疯,别人下个包.下个镜像几秒钟搞定,我看着我的几KB小水管真是有苦说不出),另一个就是这里面坑还是有一些的,写 ...

  10. Mybatis学习之自定义持久层框架(五) 自定义持久层框架:封装CRUD操作

    前言 上一篇文章我们完成了生产sqlSession的工作,与数据库的连接和创建会话的工作都已完成,今天我们可以来决定会话的内容了. 封装CRUD操作 首先我们需要创建一个SqlSession接口类,在 ...