本文实例为大家分享了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 "");
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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“TableSort.js表格排序插件使用方法详解”评论...
更新日志
2025年10月27日
2025年10月27日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]