本文实例为大家分享了TableSort.js表格排序的具体代码,供大家参考,具体内容如下
<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>TableSort</title> <style type="text/css"> table { border-collapse: collapse; width: 300px; } table caption { border-right: 1px solid #abc; border-left: 1px solid #abc; border-top: 2px solid #000; border-bottom: 2px solid #000; background-color: #afd; } #sales tr, #sales td { border: 1px solid #abc; text-align: center; } </style> </head> <body> <table id="sales" summary="summary here"> <caption> Main Title </caption> <col/> <col/> <col/> <thead> <tr> <th class="asc">Col1</th> <th>Col2</th> <th>Col3</th> </tr> </thead> <tbody> <tr> <td>A1</td> <td>S2</td> <td>W3</td> </tr> <tr> <td>B1</td> <td>C2</td> <td>V3</td> </tr> <tr> <td>C1</td> <td>X2</td> <td>K3</td> </tr> </tbody> <!-- tfoot><tr><td cols=3 >other description</td></tr></tfoot --> </table> <button onclick="fn()">Test</button> <script language="javascript"> function TableSort(id) { this.tbl = document.getElementById(id); this.lastSortedTh = null; if (this.tbl && this.tbl.nodeName == "TABLE") { var headings = this.tbl.tHead.rows[0].cells; for (var i = 0; headings[i]; i++) { if (headings[i].className.match(/asc|dsc/)) { this.lastSortedTh = headings[i]; } } this.makeSortable(); } } TableSort.prototype.makeSortable = function() { var headings = this.tbl.tHead.rows[0].cells; for (var i = 0; headings[i]; i++) { headings[i].cIdx = i; var a = document.createElement("a"); a.href = "#"; a.innerHTML = headings[i].innerHTML; a.onclick = function(that) { return function() { that.sortCol(this); return false; } }(this); headings[i].innerHTML = ""; headings[i].appendChild(a); } } TableSort.prototype.sortCol = function(el) { var rows = this.tbl.rows; var alpha = [], numeric = []; var aIdx = 0, nIdx = 0; var th = el.parentNode; var cellIndex = th.cIdx; for (var i = 1; rows[i]; i++) { var cell = rows[i].cells[cellIndex]; var content = cell.textContent ? cell.textContent : cell.innerText; var num = content.replace(/(\$|\,|\s)/g, ""); if (parseFloat(num) == num) { numeric[nIdx++] = { value : Number(num), row : rows[i] } } else { alpha[aIdx++] = { value : content, row : rows[i] } } } function bubbleSort(arr, dir) { var start, end; if (dir === 1) { start = 0; end = arr.length; } else if (dir === -1) { start = arr.length - 1; end = -1; } var unsorted = true; while (unsorted) { unsorted = false; for (var i = start; i != end; i = i + dir) { if (arr[i + dir] && arr[i].value > arr[i + dir].value) { var temp = arr[i]; arr[i] = arr[i + dir]; arr[i + dir] = temp; unsorted = true; } } } return arr; } var col = [], top, bottom; if (th.className.match("asc")) { top = bubbleSort(alpha, -1); bottom = bubbleSort(numeric, -1); th.className = th.className.replace(/asc/, "dsc"); } else { top = bubbleSort(numeric, 1); bottom = bubbleSort(alpha, 1); if (th.className.match("dsc")) { th.className = th.className.replace(/dsc/, "asc"); } else { th.className += "asc"; } } if (this.lastSortedTh && th != this.lastSortedTh) { this.lastSortedTh.className = this.lastSortedTh.className.replace( /dsc|asc/g, ""); } this.lastSortedTh = th; col = top.concat(bottom); var tBody = this.tbl.tBodies[0]; for (var i = 0; col[i]; i++) { tBody.appendChild(col[i].row); } } function fn() { var sales = document.getElementById('sales'); var sortTable = new TableSort('sales'); } </script> </body> </html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍vue拖拽排序插件vuedraggable使用方法详解,包括了vue拖拽排序插件vuedraggable使用方法详解的使用技巧和注意事项,需要的朋友参考一下 大家好,最近做的项目要用到拖拽排序,我现在的项目是vue项目,所以我就屁颠屁颠的去百度有木有这样功能的插件,我就知道一定会有,那就是vuedraggable,这是一款很棒的拖拽插件,下面我来说一下怎么引入 首先在vue项目中,用
本文向大家介绍jQuery表格插件datatables用法详解,包括了jQuery表格插件datatables用法详解的使用技巧和注意事项,需要的朋友参考一下 一、Datatables简介 DataTables是一个jQuery的表格插件。这是一个高度灵活的工具,依据的基础逐步增强,这将增加先进的互动控制,支持任何HTML表格。主要特点: 自动分页处理 即时表格数据过滤 数据排序以及数据类型自动检
本文向大家介绍bootstrap table表格插件使用详解,包括了bootstrap table表格插件使用详解的使用技巧和注意事项,需要的朋友参考一下 bootstrp-table学习,具体内容如下 bootstrap-table是一种表格插件,可用作后管系统的数据处理和回显,当然,bootstrap-table的使用需要前后台协调进行。 在使用bootstrap-table过程中需要注意:
本文向大家介绍tablesorter.js表格排序使用方法(支持中文排序),包括了tablesorter.js表格排序使用方法(支持中文排序)的使用技巧和注意事项,需要的朋友参考一下 最近,因为项目需要,对表格排序做了一下摸索,整理如下: 1. 首先,可从官网下载tablesorter.js,但并不支持中文的排序,对其源码进行修改: 部分源码: 修改后: 修改完之后的js可支持中文的排序。 2.建
本文向大家介绍jquery表单插件Autotab使用方法详解,包括了jquery表单插件Autotab使用方法详解的使用技巧和注意事项,需要的朋友参考一下 Autotab也是一款功能专一的表单插件,它提供了自动跳格的功能,当用户输入的字符数一旦超过已定义的最大长度,则会根据事先设置的目标自动跳转到相应元素上,省却了 用户按【Tab】键的麻烦。最典型的应用就是输入IP地址、软件激活码等地方了,我们做
本文向大家介绍Bootstrap表格使用方法详解,包括了Bootstrap表格使用方法详解的使用技巧和注意事项,需要的朋友参考一下 下表列出了 Bootstrap 支持的一些表格元素: 表格类: .table:为任意 <table> 添加基本样式 (只有横向分隔线) .table-striped:在 <tbody> 内添加斑马线形式的条纹 ( IE8 不支持) .table-bordered:为所