对table根据某个属性值进行排序

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了对table根据某个属性值进行排序相关的知识,希望对你有一定的参考价值。

问题:给定一个table如下,点击按钮根据年龄对表进行排序;

技术分享

 1 <table border="" cellspacing="" cellpadding="">
 2     <tr><th>姓名</th><th>年龄</th></tr>
 3     <tr><td>a</td><td>2</td></tr>
 4     <tr><td>b</td><td>4</td></tr>
 5     <tr><td>c</td><td>5</td></tr>
 6     <tr><td>d</td><td>1</td></tr>
 7     <tr><td>e</td><td>3</td></tr>
 8 </table>
 9 <input type="button" value = "sort"/>

思路:

1.将dom中的tr放到数组中;

2.利用数组的sort方法排序;

3.排序完毕后用重绘页面;

 

代码如下:

 1 var btn = document.getElementsByTagName("input")[0];
 2 var trs = document.getElementsByTagName("tr");
 3 var arr = [];
 4 for(var i = 1;i<trs.length;i++){
 5     arr.push(trs[i]);
 6 }
 7 btn.onclick = function(){
 8     arr.sort(function(x,y){
 9         return x.getElementsByTagName("td")[1].innerhtml-y.getElementsByTagName("td")[1].innerHTML
10     }).forEach(function(i){
11         document.getElementsByTagName("table")[0].appendChild(i);
12     })
13     
14 }

 

以上是关于对table根据某个属性值进行排序的主要内容,如果未能解决你的问题,请参考以下文章

根据值的属性对 PowerShell 哈希表进行排序

Python入门题045:根据对象属性进行排序

按对象属性之一的值对对象列表进行排序,其中只有一个值是感兴趣的

根据两个或多个值对通用列表进行排序

根据属性值(int)对对象数组进行排序[重复]

js先后对某个js对象内的两个属性排序