爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
JS特效
利用js对表格进行排序(包括数值、字符串、日期等数据类型)
利用js对表格进行排序(包括数值、字符串、日期等数据类型)
日期:2014-05-18 浏览次数:20284 次
以下是程序代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"><head> <meta content="text/html; charset=UTF-8" http-equiv="Content-Type"> <title>爱易网 特效演示页 sort table -- by zhangchen</title> <style type="text/css"> * { padding:0; margin:0; } body { font-family:verdana; font-size:12px; } .content { width:550px; margin:20px auto; } .content h1 { font-family:'微软雅黑'; font-size:18px; padding-bottom:5px; } table { width:100%; } th, td { padding:6px 0; text-align:center; } th { background-color:#007D28; color:#ffffff; } tr { background-color:#E8FFE8; } .odd { background-color:#FFF3EE; } .highlight { background-color:#FFF3EE; } </style> <script type="text/javascript"> //动态给js添加class属性 function addClass(element, value) { if(!element.className) { element.className = value; //如果element本身不存在class,则直接添加class为value的值 } else { element.className += " "+value; //如果element之前有一个class值,注意中间要多一个空格,然后再加上value的值 } } //鼠标经过时高亮显示 function highlightRows() { var rows = document.getElementsByTagName("tr"); for(var i=0; i<rows.length; i++) { rows[i].oldClassName = rows[i].className; //首先保存之前的class值 rows[i].onmouseover = function() { addClass(this, "highlight"); //鼠标经过时添加class为highlight的值 } rows[i].onmouseout = function() { this.className = this.oldClassName; //鼠标离开时还原之前的class值 } } } //比较之前进行数据转换 function convert(value, dataType) { switch(dataType) { case "int": return parseInt(value); break case "float": return parseFloat(value); break case "date": return Date.parse(value); break default: return value.toString(); } } //用于sort比较字符串 function compareCols(col, dataType) { return function compareTrs(tr1, tr2) { value1 = convert(tr1.cells[col].innerHTML, dataType); value2 = convert(tr2.cells[col].innerHTML, dataType); if (value1 < value2) { return -1; } else if (value1 > value2) { return 1; } else { return 0; } }; } //对表格进行排序 function sortTable(tableId, col, dataType) { 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 == col) { trValue.reverse(); //如果该列已经进行排序过了,则直接对其反序排列 } else { trValue.sort(compareCols(col, dataType)); //进行排序 } var fragment = document.createDocumentFragment(); //新建一个代码片段,用于保存排序后的结果 for (var i=0; i<trValue.length; i++ ) { fragment.appendChild(trValue[i]); } tbody.appendChild(fragment); //将排序的结果替换掉之前的值 tbody.sortCol = col; } window.onload = function() { highlightRows(); } </script> </head> <body> <div class="content"> <h1>会员信息表(点击表格标题可进行排序)</h1> <table summary="user infomation table" id="tableSort"> <thead> <tr> <th onclick="sortTable('tableSort', 0, 'int')" style="cursor: pointer;">会员ID</th> <th onclick="sortTable('tableSort', 1)" style="cursor: pointer;">会员名</th> <th onclick="sortTable('tableSort', 2)" style="cursor: pointer;">邮箱</th> <th onclick="sortTable('tableSort', 3)" style="cursor: pointer;">会员组</th> <th onclick=
上一篇:狡猾的按钮特效
下一篇:div展开收缩特效代码
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
王建宙解构OTT效劳 中移动重塑飞信平台
网曝富士康“二连跳” 疑因推静音模式
HTC手机为何一败再败?效果出在供应链
电信资费新政:三巨头压力大 短期降价仍有争议
虚拟运营商们更像三大运营商的“二道贩子”
苹果App Store被大量刷榜:iTunes账号成帮凶
阿里巴巴IPO难掩的四个现实问题:天猫销售额成谜、淘宝拖后腿、营收迅猛其他不行和投资者未必买账
曹国伟:微博将关注Facebook和Twitter
谁说黑莓没救?他们在悄悄地深耕企业级市场,在这个领域,苹果三星算什么,他们远远不是黑莓的对手
推荐阅读
更多>
网易微博将正式关闭 用户迁至轻博客LOFTER
央行暂停二维码支付及虚拟信用卡 支付宝微信不知情
欧洲6万人起诉Facebook隐私侵权
iPhone5S组件曝光 印证杀手级功能存在
地图导航骤起杀机 百度高德重新定义商业模式
蜗牛移动董事长石海:号卡被叫停属乌龙事件
微软小冰复活再战移动端:改与米聊、易信和触宝合作
携程整合去哪儿陷入僵局 欲联手老对手艺龙
阿里物流搭上邮政:京东,我们在终点等你!
亚马逊Fire Phone:请别拿我跟苹果三星比
Line风靡亚洲,在北美却进展缓慢
Kindle入华遭遇国内厂商“围剿 ” 电信也参战
用友软件股价逆势下跌 再融资方案现曙光
众贷网满月开张 网络金融监管再受质疑
【晚报】女子泰国游晒10照片 流量费2000
《中国三网融合业务运营管理》研讨报告征订函
华为变阵:任正非调整三大业务布局
互联网金融一周年:余额宝最接地气,比特币最作死
亚马逊落户上海自贸区:美国货直邮中国
HTC曝出特大丑闻:高管诈骗+商业间谍