js实现表格的排序功能
2015-09-06 14:59
651 查看
之前的阿里线上笔试最后一道就是实现表格的排序功能,但当时由于时间有限没能完成,于是今天趁着午休时间完成了这个功能。
下面附上代码(有注释):(该功能是完成了对age的升序(从小到大)的排序)
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style type="text/css">
table {
border: 1px solid #ccc;
width: 1000px;
margin: 20px auto;
border-collapse: collapse;
border-spacing: 0px;
text-align: center;
}
th {
}
tr {
border: 2px solid #ccc;
}
</style>
</head>
<body>
<table class="tab">
<tr><th>name</th><th>age</th></tr>
<tbody class="tbody">
<tr><td>name1</td><td>12</td></tr>
<tr><td>name2</td><td>15</td></tr>
<tr><td>name3</td><td>1</td></tr>
<tr><td>name4</td><td>16</td></tr>
<tr><td>name5</td><td>5</td></tr>
</tbody>
</table>
<p class="display"></p>
<script type="text/javascript" src="js/jquery-1.9.1.js"></script>
<script type="text/javascript">
$(function(){
var $tr = $(".tbody").find('tr');
var array =[];//[{index:0,age:12},{index:1,age:15}~~~]
$tr.each(function(){
var obj ={};
obj["index"] = $(this).index();
obj["age"] = $(this).children('td').last().html();
obj["name"] = $(this).children('td').first().html();
array.push(obj);
});
for(var i =0 ;i<array.length;i++){
console.log(array[i]);
}
$.each(array,function(i,elem){
console.log(array[i].age);
});
//排序
array.sort(sortBy);
function sortBy(a,b){
return a.age-b.age;
}
for(var i =0 ;i<array.length;i++){
console.log(array[i]);
}
//删除旧数组生成新数组
$('.tbody').empty().append($tr);
for(var i =0 ;i<array.length;i++){
$('.tbody').append($tr.eq(array[i].index));
}
});
</script>
</body>
</html>
代码部分最主要的还是js部分,我的主要思路是通过建立一个数组对象,将每一列的列数和age的大小放进去,然后通过对age的排序实现对这个对象数组的排序,最后再删除旧的表格生成新的表格。
下面附上代码(有注释):(该功能是完成了对age的升序(从小到大)的排序)
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style type="text/css">
table {
border: 1px solid #ccc;
width: 1000px;
margin: 20px auto;
border-collapse: collapse;
border-spacing: 0px;
text-align: center;
}
th {
}
tr {
border: 2px solid #ccc;
}
</style>
</head>
<body>
<table class="tab">
<tr><th>name</th><th>age</th></tr>
<tbody class="tbody">
<tr><td>name1</td><td>12</td></tr>
<tr><td>name2</td><td>15</td></tr>
<tr><td>name3</td><td>1</td></tr>
<tr><td>name4</td><td>16</td></tr>
<tr><td>name5</td><td>5</td></tr>
</tbody>
</table>
<p class="display"></p>
<script type="text/javascript" src="js/jquery-1.9.1.js"></script>
<script type="text/javascript">
$(function(){
var $tr = $(".tbody").find('tr');
var array =[];//[{index:0,age:12},{index:1,age:15}~~~]
$tr.each(function(){
var obj ={};
obj["index"] = $(this).index();
obj["age"] = $(this).children('td').last().html();
obj["name"] = $(this).children('td').first().html();
array.push(obj);
});
for(var i =0 ;i<array.length;i++){
console.log(array[i]);
}
$.each(array,function(i,elem){
console.log(array[i].age);
});
//排序
array.sort(sortBy);
function sortBy(a,b){
return a.age-b.age;
}
for(var i =0 ;i<array.length;i++){
console.log(array[i]);
}
//删除旧数组生成新数组
$('.tbody').empty().append($tr);
for(var i =0 ;i<array.length;i++){
$('.tbody').append($tr.eq(array[i].index));
}
});
</script>
</body>
</html>
代码部分最主要的还是js部分,我的主要思路是通过建立一个数组对象,将每一列的列数和age的大小放进去,然后通过对age的排序实现对这个对象数组的排序,最后再删除旧的表格生成新的表格。
相关文章推荐
- Extjs4.0 最新最全视频教程
- Javascript中toFixed方法的改进
- 5个常见可用性错误和解决方案
- easyui------显示隐藏列功能
- js可突破windows弹退效果代码
- JSP脚本漏洞面面观
- 使用BAT一句话命令实现快速合并JS、CSS
- js显示当前星期的起止日期的脚本
- 爆炸式的JS圆形浮动菜单特效代码
- js select常用操作控制代码
- 从jsp发送动态图像
- 原生js结合html5制作小飞龙的简易跳球
- js 页面模块自由拖动实例
- js实现小鱼吐泡泡在页面游动特效
- js 提交和设置表单的值
- PHP VBS JS 函数 对照表
- PHP+JS实现大规模数据提交的方法
- 仿51JOB的地区选择效果(可选择多个地区)
- js身份证验证超强脚本