【JS】根据表格ID进行排序(附注释)

分享一个前端做的根据表格ID进行排序的方法哈,贴码如下:

HTML:

<input type="button" id="btn1" value="排序"/>

    <table id="tab1" border="1" width="500">
    	<thead>
    		<td>ID</td>
    		<td>姓名</td>
    		<td>年龄</td>
    	</thead>
    	<tbody>
    		<tr>
    			<td>3</td>
    			<td>hello</td>
    			<td>22</td>
    		</tr>
    		<tr>
    			<td>1</td>
    			<td>man</td>
    			<td>35</td>
    		</tr>
    		<tr>
    			<td>4</td>
    			<td>girl</td>
    			<td>24</td>
    		</tr>
    		<tr>
    			<td>5</td>
    			<td>woman</td>
    			<td>37</td>
    		</tr>
    		<tr>
    			<td>2</td>
    			<td>guy</td>
    			<td>19</td>
    		</tr>
    	</tbody>
    </table>

JS:

window.onload=function(){
		var oTab=document.getElementById('tab1');	//获取表格
		var oBtn=document.getElementById('btn1');	//获取排序按钮,方便下面的点击操作

		oBtn.onclick=function(){
			var arr=[];		//定义一个空的数组
			for(var i=0;i<oTab.tBodies[0].rows.length;i++){
				arr[i]=oTab.tBodies[0].rows[i];		//把表格的所有行数都存到arr数组里
			}
			arr.sort(function(tr1,tr2){		//这里传入两个参数用于比较
				var n1=parseInt(tr1.cells[0].innerHTML);	//这里取出表格里的行的第一个单元格,对应ID所在的单元格
				var n2=parseInt(tr2.cells[0].innerHTML);
				return n1-n2;	//若想倒序,可以修改为return n2-n1
			});
			for(var i=0;i<arr.length;i++){
				oTab.tBodies[0].appendChild(arr[i]);	//把上面sort排好序的元素一行行地按顺序重新插入到表格中
			}
		};
	};
排序前:

【JS】根据表格ID进行排序(附注释)_第1张图片

排序后:

【JS】根据表格ID进行排序(附注释)_第2张图片


Author:致知

Sign:路漫漫其修远兮,吾将上下而求索。


你可能感兴趣的:(表格排序)