JavaScript表格排序()转

王朝学院·作者佚名  2009-09-15
窄屏简体版  字體: |||超大  

<!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>

<title>JavaScript表格排序</title>

</head>

<body>

<table style="width: 151px" id="t1">

<tr>

<td style="cursor:pointer">

标题1</td>

<td>

标题2</td>

<td>

标题3</td>

</tr>

<tr>

<td>

a</td>

<td>

3</td>

<td>

d</td>

</tr>

<tr>

<td>

b</td>

<td>

2</td>

<td>

c</td>

</tr>

<tr>

<td>

c</td>

<td>

1</td>

<td>

a</td>

</tr>

</table>

<script>

enableTableSort("t1");

function enableTableSort(id)

{

var mytable=document.getElementById(id);

for(var i=0;i<mytable.rows[0].cells.length;i++)

{

mytable.rows[0].cells[i].onclick=sortTable(id,i);

mytable.rows[0].cells[i].style.cursor="pointer";

mytable.rows[0].cells[i].style.background="#f0f000";

}

function sortrow(cellIndex,sortDirection)

{

return function(row1,row2)

{

var value1= row1.cells[cellIndex].firstChild.nodeValue

var value2= row2.cells[cellIndex].firstChild.nodeValue

if(value1>value2)

{

return sortDirection

}

else if(value1<value2)

{

return sortDirection;

}

else return 0;

}

}

function sortTable(id,cellIndex)

{

return function()

{

var mytable=document.getElementById(id);

var tbody=mytable.tBodies[0];

var trows=tbody.rows;

var sortDirection=mytable.getAttribute("sortDirection")?mytable.getAttribute("sortDirection"):1;

var arows=[];

for(var i=1;i<trows.length;i++)

arows.push(trows[i]);

mytable.setAttribute("sortDirection",sortDirection?-1:1)

arows.sort(sortrow(cellIndex,sortDirection));

var docFragment=document.createDocumentFragment();

for(var i=0;i<arows.length;i++)

{

docFragment.appendChild(arows[i]);

}

tbody.appendChild(docFragment);

}

}

}

</script>

</body>

</html>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航