javascript表格排序(包括中文排序)

<html>
<head>
<script language="javascript">
function sortTable(tableId,iCol,dataType) {
var oTable = document.getElementById(tableId);
var oTbody = oTable.tBodies[0];
var oRows = oTbody.rows;
var oTrs = [];
for(var i=0;i<oRows.length;i++) {
oTrs[i] = oRows[i];
}
if(oTable.sortCol == iCol) {
oTrs.reverse();
} else {
oTrs.sort(generateCompareTRs(iCol,dataType));

}
var oFragment = document.createDocumentFragment();
for(var i=0;i<oTrs.length;i++) {
oFragment.appendChild(oTrs[i]);
}
oTbody.appendChild(oFragment);
oTable.sortCol = iCol;
}
function convert(oValue,dataType) {
switch(dataType) {
case "int":
return parseInt(oValue);
case "float":
return parseFloat(oValue);
case "date":
return new Date(Date.parse(oValue));
default:
return oValue;
}
}
function generateCompareTRs(iCol,dataType) {
return function compareTRs(oTR1,oTR2) {
var oValue1 = convert(oTR1.cells[iCol].firstChild.nodeValue,dataType);
var oValue2 = convert(oTR2.cells[iCol].firstChild.nodeValue,dataType);
if(dataType=="string") {
return oValue1.localeCompare(oValue2);
} else {
if(oValue1 < oValue2) {
return -1;
} else if (oValue1 > oValue2) {
return 1;
} else {
return 0;
}
}
}
}
</script>
</head>
<body>
<table id="myTable" border="1">
<thead>
<th οnclick="sortTable('myTable',0,'string')">姓名</th>
<th οnclick="sortTable('myTable',1,'string')">地名</th>
<th οnclick="sortTable('myTable',2,'int')">价格</th>
<th οnclick="sortTable('myTable',3,'string')">日期</th>
</thead>
<tbody>
<tr>
<td>张明强</td><td>泉州</td><td>544</td><td>2010-10-10</td>
</tr>
<tr>
<td>林水明</td><td>贵州</td><td>62</td><td>2011-10-10</td>
</tr>
<tr>
<td>严跃宁</td><td>山东</td><td>4369</td><td>2009-10-10</td>
</tr>
<tr>
<td>杨龙通</td><td>济南</td><td>123456</td><td>2010-09-09</td>
</tr>
<tr>
<td>陆文邦</td><td>北京</td><td>644</td><td>2020-10-10</td>
</tr>
<tr>
<td>阿 Q</td><td>江西</td><td>89</td><td>2008-10-10</td>
</tr>
<tr>
<td>郭靖</td><td>杭州</td><td>999</td><td>2010-11-11</td>
</tr>
<tr>
<td>一灯</td><td>安徽</td><td>369</td><td>2010-01-03</td>
</tr>
<tr>
<td>小胖子</td><td>黑龙江</td><td>44</td><td>2010-05-05</td>
</tr>
<tr>
<td>窑子</td><td>启元</td><td>744</td><td>2010-03-03</td>
</tr>
<tr>
<td>兰花儿</td><td>云南</td><td>7544</td><td>2013-07-07</td>
</tr>
<tr>
<td>喇嘛</td><td>西藏</td><td>66</td><td>2010-08-08</td>
</tr>
</tbody>
</table>
</body>
</html>

注意:localeCompare()可以处理中文排序问题,如果是字符串类型的话一定要传入string类型。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值