jquery table 排序
2013年8月3日
3 条评论
借助于强大的jquery库,通过一些简单的js代码来实现对table数据列进行排序。排序是通过调整table的tr的顺序重新显示,全部在客户端上完成,不需要和服务器交互,因此减轻了服务器的压力。查看Demo请猛点这里。
实现排序的js代码如下:
function tableSort(jqTableObj) {
jqTableObj.find('thead th').click(
function(){
var dataType = $(this).attr('dataType') || 'text';
var index = jqTableObj.find('thead th').index(this) + 1;
var arr = [];
var row = jqTableObj.find('tbody tr');
$.each(row, function(i){arr[i] = row[i]});
if($(this).hasClass('current')){
arr.reverse();
} else {
arr.sort(Utils.sortStr(index, dataType))
jqTableObj.find('thead th').removeClass('current');
$(this).addClass('current');
}
var fragment = document.createDocumentFragment();
$.each(arr, function(i){
fragment.appendChild(arr[i]);
});
jqTableObj.find('tbody').append(fragment);
}
);
var Utils = (function() {
function sortStr(index, dataType){
return function(a, b){
var aText=$(a).find('td:nth-child(' + index + ')').attr('_order') || $(a).find('td:nth-child(' + index + ')').text();
var bText=$(b).find('td:nth-child(' + index + ')').attr('_order') || $(b).find('td:nth-child(' + index + ')').text();
if(dataType != 'text'){
aText=parseNonText(aText, dataType);
bText=parseNonText(bText, dataType);
return aText > bText ? -1 : bText > aText ? 1 : 0;
} else {
return aText.localeCompare(bText)
}
}
}
function parseNonText(data, dataType){
switch(dataType){
case 'int':
return parseInt(data) || 0
case 'float':
return parseFloat(data) || 0
default :
return filterStr(data)
}
}
//过滤中文字符和$
function filterStr(data){
if (!data) {
return 0;
}
return parseFloat(data.replace(/^[\$a-zA-z\u4e00-\u9fa5 ]*(.*?)[a-zA-z\u4e00-\u9fa5 ]*$/,'$1'));
}
return {'sortStr' : sortStr};
})();
}
要想让上面的代码工作,需要在原有的table中注意几点。
1、表头的tr其父元素为thead,另外表头列使用th,同时要使用dataType属性名来标示数据的类型,类型可以为text(默认),int和float;
2、显示table数据的tr父元素为tbody,显示数据的列用td,可以使用_order属性指定该字段的真实值。
table 示例如下:
<table>
<thead>
<tr>
<th datatype="int">ID</th>
<th datatype="text">Username</th>
<th datatype="float" class="current">Revenue</th>
</tr>
</thead>
<tbody>
<tr>
<td>1032</td>
<td>Zhang</td>
<td _order="127579">$ 127,579.00</td>
</tr>
<tr>
<td>1074</td>
<td>gm1</td>
<td _order="37331">$ 37,331.00</td>
</tr>
</tbody>
<tfoot>
<tr>
<th colspan="2">Summary</th>
<th>$ 164,910.00
</tr>
</tfoot>
</table>
