Copy the code code as follows:
<script type="text/javascript">
var b = true;
function sortAge(){
var tabNode = document.getElementsByTagName("table")[0];
var trNodes = tabNode.rows; //Get row objects in the table
var arr = new Array();
for(var x=1;x<trNodes.length;x++){ //The temporary container stores references to row objects in the table
arr[x-1] = trNodes[x];
}
sort(arr);
var tbdNode = tabNode.childNodes[0];
if(b){ //if....else...controls sorting by increasing or decreasing age
for(var x=0;x<arr.length;x++){
tbdNode.appendChild(arr[x]);
}
b = false;
}else{
for(var x=arr.length-1;x>=0;x--){
tbdNode.appendChild(arr[x]);
}
b = true;
}
}
function sort(arr){ // Sort
for(var x=0;x<arr.length;x++){
for(var y=x+1;y<arr.length;y++){
if(parseInt(arr[x].cells[1].innerText)>parseInt(arr[y].cells[1].innerText)){ // Without parseInt conversion, ASCII comparison of strings is performed
var temp = arr[x];
arr[x] = arr[y];
arr[y] = temp;
}
}
}
}
</script>
<style type="text/css">
table{ width:60%; border:solid 1px #0066FF;}
table td {border:solid 1px #0099ff;}
a{ text-decoration: none;}
</style>
</head>
<body>
<table>
<tr>
<td>Name</td><td><a href="javascript:void(0)" onclick="sortAge()">Age</a></td><td>Address</td>
</tr>
<tr>
<td>Zhang San</td><td>23</td><td>Beijing</td>
</tr>
<tr>
<td>李思</td><td>25</td><td>Shanghai</td>
</tr>
<tr>
<td>王五</td><td>15</td><td>Guangzhou</td>
</tr>
<tr>
<td>Mr. Tang</td><td>20</td><td>Changsha</td>
</tr>
</table>
</body>