js实现表格的排序功能

36 篇文章 0 订阅
13 篇文章 0 订阅

之前的阿里线上笔试最后一道就是实现表格的排序功能,但当时由于时间有限没能完成,于是今天趁着午休时间完成了这个功能。

下面附上代码(有注释):(该功能是完成了对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的排序实现对这个对象数组的排序,最后再删除旧的表格生成新的表格。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值