这篇文章主要介绍了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四种数据类型)的详细内容。