本文实例讲述了jQuery实现的表格前端排序功能。分享给大家供大家参考,具体如下:

表格前端按列排序
依赖jQuery(本例使用jQuery-1.8.2)
1.初始化方法
(function($){
//插件
$.extend($,{
//命名空间
sortTable:{
sort:function(tableId,Idx){
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 == Idx) {
trValue.reverse(); //如果该列已经进行排序过了,则直接对其反序排列
} else {
trValue.sort(function(tr1, tr2){
var value1 = tr1.cells[Idx].innerText; //列
var value2 = tr2.cells[Idx].innerText; //第二列
value1 = value1.replace("%",""); //把有%的取消掉
value1=value1.trim(); //去空格
console.log(typeof(value1));
if(isNaN(value1)){
var index1 = value1.indexOf("分");
var index2 = value2.indexOf("分");
if(index1>0){
var num1 =value1.substring(0,index1);
var num2 =value1.substring(index1+1,value1.length-1);
var num3 =value2.substring(0,index2);
var num4 =value2.substring(index2+1,value2.length-1);
if(parseFloat(num1)>parseFloat(num3)){
return 1;
}
if(parseFloat(num1)<parseFloat(num3)){
return -1;
}
if(parseFloat(num1)==parseFloat(num3)){
return parseFloat(num2)-parseFloat(num4)
}
}else{
var a = tr1.cells[Idx].textContent;
var b= tr2.cells[Idx].textContent;
return a.localeCompare(b);
}
}else{
return parseFloat(value1)-parseFloat(value2);
}
});
}
var fragment = document.createDocumentFragment(); //新建一个代码片段,用于保存排序后的结果
//var index = 0;
var arrtotal =new Array();
for (var i=0; i<trValue.length; i++ ) {
var c = trValue[i].cells[0].innerHTML;
//console.log(c);
if(c.trim().indexOf("汇总")!=-1){//汇总行总是排在表格最上面
// index = i;
arrtotal.push(i);
}else{
fragment.appendChild(trValue[i]);
}
}
if(arrtotal.length>0){
for(var k=arrtotal.length; k<0; k-- ){
tbody.appendChild(trValue[arrtotal[k]]);
}
}
//tbody.appendChild(trValue[index]);
tbody.appendChild(fragment); //将排序的结果替换掉之前的值
tbody.sortCol = Idx;
}
}
});
})(jQuery);
2.页面函数
function desc_change(id,str){
$("#desc_1").html("日期");
$("#desc_2").html("ID");
$("#desc_3").html("类别");
$("#"+id).html(str);
}
function desc(id,str){
var htmlstr =$("#"+id).text().trim();
var c =str;
if(htmlstr==str){
c=str+'↓';
$("#"+id).html(c);
}else if(htmlstr==str+'↓'){
c=str+'↑'
$("#"+id).html(c);
}else if(htmlstr==str+'↑'){
c=str+'↓'
$("#"+id).html(c);
}
desc_change(id,c)
}
3.DOM结构
<table id="tableSort">
<thead>
<tr>
<th onclick="$.sortTable.sort('tableSort',0);desc('desc_1','日期')" ><a id="desc_1" >日期</a></th>
<th onclick="$.sortTable.sort('tableSort',1);desc('desc_2','软件ID')" ><a id="desc_2" >ID</a></th>
<th onclick="$.sortTable.sort('tableSort',2);desc('desc_x','渠道ID')" ><a id="desc_3" >类别</a></th>
</tr>
</thead>
<tbody>
<tr>
<td>201870601</td>
<td>汇总</td>
<td>新闻</td>
</tr>
</tbody>
</table>
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery表格(table)操作技巧汇总》、《jQuery切换特效与技巧总结》、《jQuery扩展技巧总结》、《jQuery常用插件及用法总结》、《jQuery常见经典特效汇总》及《jquery选择器用法总结》
希望本文所述对大家jQuery程序设计有所帮助。
# jQuery
# 表格
# 排序
# jQuery表格排序组件-tablesorter使用示例
# 基于jquery的表格排序
# Jquery 选中表格一列并对表格排序实现原理
# jquery tablesorter.js 支持中文表格排序改进
# jQuery+Ajax实现表格数据不同列标题排序(为表格注入活力)
# jquery 表格排序、实时搜索表格内容(附图)
# 扩展jquery实现客户端表格的分页、排序功能代码
# jquery实现表格本地排序的方法
# jquery.tableSort.js表格排序插件使用方法详解
# 基于jQuery实现表格的排序
# jQuery增加和删除表格项目及实现表格项目排序的方法
# jQuery html表格排序插件tablesorter使用方法详解
# 相关内容
# 过了
# 感兴趣
# 对其
# 给大家
# 排在
# 更多关于
# 所述
# 程序设计
# 新建一个
# 组中
# 本例
# 操作技巧
# 选择器
# 讲述了
# 反序
# length
# lt
# td
# sortCol
相关文章:
临沂网站制作企业,临沂第三中学官方网站?
表情包在线制作网站免费,表情包怎么弄?
网站制作难吗安全吗,做一个网站需要多久时间?
网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?
股票网站制作软件,网上股票怎么开户?
建站之星导航菜单设置与功能模块配置全攻略
如何在景安服务器上快速搭建个人网站?
建站之星2.7模板:企业网站建设与h5定制设计专题
C++如何编写函数模板?(泛型编程入门)
定制建站哪家更专业可靠?推荐榜单揭晓
制作网站的过程怎么写,用凡科建站如何制作自己的网站?
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
外贸公司网站制作哪家好,maersk船公司官网?
如何通过VPS搭建网站快速盈利?
定制建站价位费用解析与套餐推荐全攻略
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
网站制作服务平台,有什么网站可以发布本地服务信息?
如何零基础在云服务器搭建WordPress站点?
宝塔建站教程:一键部署配置流程与SEO优化实战指南
正规网站制作公司有哪些,目前国内哪家网页网站制作设计公司比较专业靠谱?口碑好?
制作营销网站公司,淘特是干什么用的?
建站之星微信建站一键生成小程序+多端营销系统
开心动漫网站制作软件下载,十分开心动画为何停播?
网页设计与网站制作内容,怎样注册网站?
Java解压缩zip - 解压缩多个文件或文件夹实例
建站之星安装后界面空白如何解决?
宝塔面板创建网站无法访问?如何快速排查修复?
黑客如何通过漏洞一步步攻陷网站服务器?
建站主机选购指南与交易推荐:核心配置解析
网站制作软件有哪些,制图软件有哪些?
c# Task.ConfigureAwait(true) 在什么场景下是必须的
上海网站制作网页,上海本地的生活网站有哪些?最好包括生活的各个方面的?
如何通过网站建站时间优化SEO与用户体验?
如何在搬瓦工VPS快速搭建网站?
Python如何创建带属性的XML节点
建站之星免费模板:自助建站系统与智能响应式一键生成
宝盒自助建站智能生成技巧:SEO优化与关键词设置指南
如何选择高性价比服务器搭建个人网站?
Swift中循环语句中的转移语句 break 和 continue
如何通过cPanel快速搭建网站?
,网页ppt怎么弄成自己的ppt?
如何快速搭建个人网站并优化SEO?
Android自定义控件实现温度旋转按钮效果
网站制作新手教程,新手建设一个网站需要注意些什么?
大连网站设计制作招聘信息,大连投诉网站有哪些?
如何在宝塔面板中修改默认建站目录?
高防服务器租用指南:配置选择与快速部署攻略
如何快速查询网址的建站时间与历史轨迹?
如何在阿里云ECS服务器部署织梦CMS网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。