效果图如下:
Demo演示地址:点击这里
主要的JS代码如下:
var tbody = document.querySelector('#tableSort').tBodies[0];
var th = document.querySelector('#tableSort').tHead.rows[0].cells;
var td = tbody.rows;
for (var i = 0;i < th.length;i++){
th[i].flag = 1;
th[i].onclick = function(){
sort(this.getAttribute('data-type'),this.flag,this.cellIndex);
this.flag = -this.flag;
};
};
function sort(str,flag,n){
var arr = []; //存放DOM
for (var i = 0;i < td.length;i++){
arr.push(td[i]);
};
//排序
arr.sort(function(a,b){
return method(str,a.cells[n].innerHTML,b.cells[n].innerHTML) * flag;
});
//添加
for (var i = 0;i < arr.length;i++){
tbody.appendChild(arr[i]);
};
};
//排序方法
function method(str,a,b){
switch (str){
case 'num': //数字排序
return a-b;
break;
case 'string': //字符串排序
return a.localeCompare(b);
break;
default: //日期排序,IE8下'2012-12-12'这种格式无法设置时间,替换成'/'
return new Date(a.split('-').join('/')).getTime()-new Date(b.split('-').join('/')).getTime();
};
};
完整实例代码
<!DOCTYPE>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>JS实现点击表头表格自动排序(含数字、字符串、日期)</title>
<style>#tableSort{moz-user-select: -moz-none;-moz-user-select: none;-o-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;user-select:none;border-collapse: collapse; border-spacing: 0; margin: 0; padding: 0;width: 100%;text-align: center;margin:15px 0;}
#tableSort th{cursor: pointer; background: #eee}
#tableSort tr:nth-child(even){background: #f9f9f9}
#tableSort th,#tableSort td{padding: 10px; border:1px solid #ccc;}
</style>
</head>
<body>
<table id="tableSort">
<thead>
<tr>
<th data-type="num">工号</th>
<th data-type="string">姓名</th>
<th data-type="string">性别</th>
<th data-type="date">时间</th>
</tr>
</thead>
<tbody>
<tr>
<td>07</td>
<td>aaaa</td>
<td>男</td>
<td>2012-12-12</td>
</tr>
<tr>
<td>03</td>
<td>mmmm</td>
<td>女</td>
<td>2013-12-16</td>
</tr>
<tr>
<td>01</td>
<td>cccc</td>
<td>男</td>
<td>2014-12-12</td>
</tr>
<tr>
<td>04</td>
<td>ffff</td>
<td>女</td>
<td>2015-12-12</td>
</tr>
<tr>
<td>02</td>
<td>bbbb</td>
<td>男</td>
<td>2016-12-18</td>
</tr>
<tr>
<td>06</td>
<td>ssss</td>
<td>女</td>
<td>2008-10-07</td>
</tr>
<tr>
<td>05</td>
<td>tttt</td>
<td>男</td>
<td>2012-07-22</td>
</tr>
</tbody>
</table>
<script>
;(function(){
var tbody = document.querySelector('#tableSort').tBodies[0];
var th = document.querySelector('#tableSort').tHead.rows[0].cells;
var td = tbody.rows;
for(var i = 0;i < th.length;i++){
th[i].flag = 1;
th[i].onclick = function(){
sort(this.getAttribute('data-type'),this.flag,this.cellIndex);
this.flag = -this.flag;
};
};
function sort(str,flag,n){
var arr = [];
for(var i = 0;i < td.length;i++){
arr.push(td[i]);
};
arr.sort(function(a,b){
return method(str,a.cells[n].innerHTML,b.cells[n].innerHTML) * flag;
});
for(var i = 0;i < arr.length;i++){
tbody.appendChild(arr[i]);
};
};
function method(str,a,b){
switch(str){
case 'num':
return a-b;
break;
case 'string':
return a.localeCompare(b);
break;
default:
return new Date(a.split('-').join('/')).getTime()-new Date(b.split('-').join('/')).getTime();
};
};
})();
</script>
</body>
</html>
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
# js对table组合排序
# js
# 表格各种排序
# js实现表格升降排序
# Javascript点击按钮随机改变数字与其颜色
# 原生JS实现点击数字小游戏
# 点击这里
# 这篇文章
# 替换成
# 有疑问
# break
# case
# num
# default
# string
# localeCompare
# push
# return
# arr
# DOM
# appendChild
# switch
# method
# innerHTML
# xmlns
# html
相关文章:
如何在云虚拟主机上快速搭建个人网站?
如何高效配置IIS服务器搭建网站?
如何零基础在云服务器搭建WordPress站点?
建站之星后台管理系统如何操作?
如何在万网主机上快速搭建网站?
购物网站制作公司有哪些,哪个购物网站比较好?
韩国服务器如何优化跨境访问实现高效连接?
建站之星安装失败:服务器环境不兼容?
建站之星如何助力网站排名飙升?揭秘高效技巧
如何用西部建站助手快速创建专业网站?
孙琪峥织梦建站教程如何优化数据库安全?
建站之星伪静态规则如何正确配置?
哈尔滨网站建设策划,哈尔滨电工证查询网站?
如何在建站之星网店版论坛获取技术支持?
手机怎么制作网站教程步骤,手机怎么做自己的网页链接?
免费ppt制作网站,有没有值得推荐的免费PPT网站?
如何通过多用户协作模板快速搭建高效企业网站?
如何选择适合PHP云建站的开源框架?
深圳网站制作费用多少钱,读秀,深圳文献港这样的网站很多只提供网上试读,但有些人只要提供试读的文章就能全篇下载,这个是怎么弄的?
广德云建站网站建设方案与建站流程优化指南
c# 在ASP.NET Core中管理和取消后台任务
已有域名建站全流程解析:网站搭建步骤与建站工具选择
已有域名和空间如何搭建网站?
建站主机服务器选购指南:轻量应用与VPS配置解析
企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?
建站之星代理如何优化在线客服效率?
如何通过虚拟机搭建网站?详细步骤解析
如何快速搭建高效可靠的建站解决方案?
实例解析Array和String方法
家庭服务器如何搭建个人网站?
如何确保FTP站点访问权限与数据传输安全?
如何快速生成可下载的建站源码工具?
企业微网站怎么做,公司网站和公众号有什么区别?
专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
建站之星后台密码遗忘?如何快速找回?
Thinkphp 中 distinct 的用法解析
如何打造高效商业网站?建站目的决定转化率
已有域名和空间如何快速搭建网站?
如何配置IIS站点权限与局域网访问?
北京的网站制作公司有哪些,哪个视频网站最好?
如何在阿里云虚拟主机上快速搭建个人网站?
微信小程序 input输入框控件详解及实例(多种示例)
专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站之星2.7模板:企业网站建设与h5定制设计专题
建站之星如何保障用户数据免受黑客入侵?
学校建站服务器如何选型才能满足性能需求?
如何通过免费商城建站系统源码自定义网站主题与功能?
建站之星各版本价格是多少?
php8.4新语法match怎么用_php8.4match表达式替代switch【方法】
*请认真填写需求信息,我们会在24小时内与您取得联系。