本文实例讲述了JS简单实现表格排序功能的方法。分享给大家供大家参考,具体如下:
思路:遍历每个li,并把它们存放到数组中去,然后通过sort()方法进行排序,再插入
<!DOCTYPE html PUBLIC"-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type"content="text/html; charset=utf-8"/> <title>排序</title> </head> <body> <input type="button"value="排序按钮"id="btn1"> <ul id="ul1"> <li>58</li> <li>8</li> <li>31</li> <li>98</li> <li>75</li> </ul> <script type="text/javascript"> window.onload=function(){ varoBtn=document.getElementById("btn1"); vararr=[]; varoUl=document.getElementById("ul1"); varaLi=oUl.getElementsByTagName("li"); vari; varbAsc=true; oBtn.onclick=function(){ for(i=0;i<aLi.length;i++){ arr[i]=aLi[i]; } arr.sort(function(li1,li2){ if(bAsc){ returnparseInt(li1.innerHTML)-parseInt(li2.innerHTML); } else{ returnparseInt(li2.innerHTML)-parseInt(li1.innerHTML); } }); for(i=0;i<arr.length;i++){ oUl.appendChild(arr[i]);//appendChild实际上分两步 1.先移除父级 2.添加到新的父级 (添加到原本的父级就相当于把当前元素拿到队列的末尾) } if(bAsc){ bAsc=false; }//==>bAsc=!bAsc; //简化写法 else{ bAsc=true; } }; } </script> </body> </html> |