您好,欢迎访问一九零五行业门户网

js表格排序实例详解(支持int,float,date,string四种数据类型)

这篇文章主要介绍了js表格排序实例分析(支持int,float,date,string四种数据类型),涉及javascript常用的升序、降序及数据类型转换等相关技巧,需要的朋友可以参考下
本文实例讲述了js表格排序的方法。分享给大家供大家参考。具体如下:
<html> <head> <title>sorttable2</title> <meta http-equiv="content-type" content="text/html; charset=utf-8"> <script type="text/javascript"> var k=0; /**//************************************************************************** 排序的主方法,有三个形参,stabletd,icol,sdatatype分别为需要排序的表格id, 需要排序的表格列号,所在列的数据类型(支持int,float,date,string四种数据类型) **************************************************************************/ function sorttable(stableid,icol,sdatatype) { var otable=document.getelementbyid(stableid);//获取表格的id var otbody=otable.tbodies[0]; //获取表格的tbody var coldatarows=otbody.rows; //获取tbody里的所有行的引用 var atrs=new array(); //定义atrs数组用于存放tbody里的行 for(var i=0;i<coldatarows.length;i++) //依次把所有行放如atrs数组 { atrs.push(coldatarows[i]); } /**//*********************************************************************** sortcol属性是额外给table添加的属性,用于作顺反两种顺序排序时的判断,区分 首次排序和后面的有序反转 ************************************************************************/ if(otable.sortcol==icol) //非首次排序 { atrs.reverse(); } else //首次排序 { if(k%2==0) //升序 { atrs.sort(generatecomparetrs(icol,sdatatype)); } else if(k%2==1) //降序 { atrs.sort(generatecomparetrs1(icol,sdatatype)); } } var ofragment=document.createdocumentfragment(); //创建文档碎片 for(var i=0;i<atrs.length;i++) //把排序过的atrs数组成员依次添加到文档碎片 { ofragment.appendchild(atrs[i]); } otbody.appendchild(ofragment); //把文档碎片添加到tbody,完成排序后的显示更新 otable.sortcol=icol; //把当前列号赋值给sortcol,以此来区分首次排序和非首次排序,//sortcol的默认值为-1 }; //比较函数,用于两项之间的排序 //升序 function generatecomparetrs(icol,sdatatype) { return function comparetrs(otr1,otr2) { var vvalue1=convert(otr1.cells[icol].firstchild.nodevalue,sdatatype); var vvalue2=convert(otr2.cells[icol].firstchild.nodevalue,sdatatype); if(vvalue1<vvalue2) { return -1; } else if(vvalue1>vvalue2) { return 1; } else { return 0; } }; }; //降序 function generatecomparetrs1(icol,sdatatype) { return function comparetrs(otr1,otr2) { var vvalue1=convert(otr1.cells[icol].firstchild.nodevalue,sdatatype); var vvalue2=convert(otr2.cells[icol].firstchild.nodevalue,sdatatype); if(vvalue1>vvalue2) { return -1; } else if(vvalue1<vvalue2) { return 1; } else { return 0; } }; }; //数据类型转换函数 function convert(svalue,sdatatype) { switch(sdatatype) { case "int":return parseint(svalue); case "float": return parsefloat(svalue); case "date":return new date(date.parse(svalue)); default:return svalue.tostring(); } }; </script> </head> <body> <form name="f1" id="f1" action="" method="post"> <table border="1" id="tblsort" sortcol="-1"> <thead> <tr> <th onclick="sorttable('tblsort',0);" style="cursor:pointer">last name</th> <th onclick="sorttable('tblsort',1)" style="cursor:pointer">first name</th> <th onclick="sorttable('tblsort',2,'date')" style="cursor:pointer">birthday</th> <th onclick="sorttable('tblsort',3,'int')" style="cursor:pointer">silbings</th> </tr> </thead> <tbody> <tr> <td>simth</td> <td>john</td> <td>7/12/1978</td> <td>50ngy/h</td> </tr> <tr> <td>johnson</td> <td>betty</td> <td>5/12/1965</td> <td>20ngy/h</td> </tr> <tr> <td>henderson</td> <td>nathan</td> <td>10/15/1977</td> <td>130ngy/h</td> </tr> <tr> <td>willianms</td> <td>james</td> <td>2/25/1949</td> <td>10ngy/h</td> </tr> <tr> <td>gilliam</td> <td>michael</td> <td>7/8/1980</td> <td>140ngy/h</td> </tr> <tr> <td>walker</td> <td>matthew</td> <td>6/18/1981</td> <td>103ngy/h</td> </tr> </tbody> </table> </form> </body> </html>
以上就是js表格排序实例详解(支持int,float,date,string四种数据类型)的详细内容。
其它类似信息

推荐信息