本文实例讲述了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(){ var oBtn=document.getElementById("btn1"); var arr=[]; var oUl=document.getElementById("ul1"); var aLi=oUl.getElementsByTagName("li"); var i; var bAsc=true; oBtn.onclick=function(){ for(i=0;i<aLi.length;i++){ arr[i]=aLi[i]; } arr.sort(function(li1,li2){ if(bAsc){ return parseInt(li1.innerHTML)-parseInt(li2.innerHTML); } else{ return parseInt(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>
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript操作DOM技巧总结》、《JavaScript数组操作技巧总结》、《JavaScript排序算法总结》、《JavaScript遍历算法与技巧总结》、《JavaScript数学运算用法总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript查找算法技巧总结》及《JavaScript错误与调试技巧总结》
希望本文所述对大家JavaScript程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:notice#nhooo.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。