最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

jQuery实现的表格前端排序功能示例

来源:动视网 责编:小采 时间:2020-11-27 22:29:42
文档

jQuery实现的表格前端排序功能示例

jQuery实现的表格前端排序功能示例:本文实例讲述了jQuery实现的表格前端排序功能。分享给大家供大家参考,具体如下: 表格前端按列排序 依赖jQuery(本例使用jQuery-1.8.2) 1.初始化方法 (function($){ //插件 $.extend($,{ //命名空间 sortTable:{ sort:function(
推荐度:
导读jQuery实现的表格前端排序功能示例:本文实例讲述了jQuery实现的表格前端排序功能。分享给大家供大家参考,具体如下: 表格前端按列排序 依赖jQuery(本例使用jQuery-1.8.2) 1.初始化方法 (function($){ //插件 $.extend($,{ //命名空间 sortTable:{ sort:function(


本文实例讲述了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实现的表格前端排序功能示例:本文实例讲述了jQuery实现的表格前端排序功能。分享给大家供大家参考,具体如下: 表格前端按列排序 依赖jQuery(本例使用jQuery-1.8.2) 1.初始化方法 (function($){ //插件 $.extend($,{ //命名空间 sortTable:{ sort:function(
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top