国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

js表格排序實例分析(支持int,float,date,string四種數據類型)

2024-05-06 16:19:28
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了js表格排序實例分析(支持int,float,date,string四種數據類型),涉及javascript常用的升序、降序及數據類型轉換等相關技巧,需要的朋友可以參考下

本文實例講述了js表格排序的方法。分享給大家供大家參考。具體如下:

 

 
  1. <html> 
  2. <head> 
  3. <title>SortTable2</title> 
  4. <meta http-equiv="content-type" content="text/html; charset=UTF-8"
  5. <script type="text/javascript"
  6. var k=0; 
  7. /**//************************************************************************** 
  8. 排序的主方法,有三個形參,STableTd,iCol,sDataType分別為需要排序的表格ID, 
  9. 需要排序的表格列號,所在列的數據類型(支持int,float,date,string四種數據類型) 
  10. **************************************************************************/ 
  11. function sortTable(sTableId,iCol,sDataType) 
  12. var oTable=document.getElementById(sTableId);//獲取表格的ID  
  13. var oTbody=oTable.tBodies[0]; //獲取表格的tbody 
  14. var colDataRows=oTbody.rows; //獲取tbody里的所有行的引用 
  15.  
  16. var aTRs=new Array(); //定義aTRs數組用于存放tbody里的行 
  17. for(var i=0;i<colDataRows.length;i++) //依次把所有行放如aTRs數組 
  18. aTRs.push(colDataRows[i]); 
  19. /**//*********************************************************************** 
  20. sortCol屬性是額外給table添加的屬性,用于作順反兩種順序排序時的判斷,區分 
  21. 首次排序和后面的有序反轉 
  22. ************************************************************************/ 
  23. if(oTable.sortCol==iCol) //非首次排序 
  24. aTRs.reverse(); 
  25. else //首次排序 
  26. if(k%2==0) //升序 
  27. aTRs.sort(generateCompareTRs(iCol,sDataType)); 
  28. else if(k%2==1) //降序 
  29. aTRs.sort(generateCompareTRs1(iCol,sDataType)); 
  30. var oFragment=document.createDocumentFragment(); //創建文檔碎片 
  31. for(var i=0;i<aTRs.length;i++) //把排序過的aTRs數組成員依次添加到文檔碎片 
  32. oFragment.appendChild(aTRs[i]); 
  33. oTbody.appendChild(oFragment); //把文檔碎片添加到tbody,完成排序后的顯示更新  
  34. oTable.sortCol=iCol; //把當前列號賦值給sortCol,以此來區分首次排序和非首次排序,//sortCol的默認值為-1 
  35. }; 
  36.  
  37. //比較函數,用于兩項之間的排序 
  38. //升序 
  39. function generateCompareTRs(iCol,sDataType) 
  40. return function compareTRs(oTR1,oTR2) 
  41. var vValue1=convert(oTR1.cells[iCol].firstChild.nodeValue,sDataType); 
  42. var vValue2=convert(oTR2.cells[iCol].firstChild.nodeValue,sDataType); 
  43. if(vValue1<vValue2) 
  44. return -1; 
  45. else if(vValue1>vValue2) 
  46. return 1; 
  47. else 
  48. return 0; 
  49. }; 
  50. }; 
  51. //降序 
  52. function generateCompareTRs1(iCol,sDataType) 
  53. return function compareTRs(oTR1,oTR2) 
  54. var vValue1=convert(oTR1.cells[iCol].firstChild.nodeValue,sDataType); 
  55. var vValue2=convert(oTR2.cells[iCol].firstChild.nodeValue,sDataType); 
  56. if(vValue1>vValue2) 
  57. return -1; 
  58. else if(vValue1<vValue2) 
  59. return 1; 
  60. else 
  61. return 0; 
  62. }; 
  63. }; 
  64. //數據類型轉換函數 
  65. function convert(sValue,sDataType) 
  66. switch(sDataType) 
  67. case "int":return parseInt(sValue); 
  68. case "float"return parseFloat(sValue); 
  69. case "date":return new Date(Date.parse(sValue)); 
  70. default:return sValue.toString(); 
  71. }; 
  72. </script> 
  73. </head> 
  74. <body> 
  75. <form name="f1" id="f1" action="" method="post"
  76. <table border="1" id="tblSort" sortCol="-1"
  77. <thead> 
  78. <tr> 
  79. <th onClick="sortTable('tblSort',0);" style="cursor:pointer">Last Name</th> 
  80. <th onClick="sortTable('tblSort',1)" style="cursor:pointer">First Name</th> 
  81. <th onClick="sortTable('tblSort',2,'date')" style="cursor:pointer">Birthday</th> 
  82. <th onClick="sortTable('tblSort',3,'int')" style="cursor:pointer">Silbings</th> 
  83. </tr> 
  84. </thead> 
  85. <tbody> 
  86. <tr> 
  87. <td>Simth</td> 
  88. <td>John</td> 
  89. <td>7/12/1978</td> 
  90. <td>50nGy/h</td> 
  91. </tr> 
  92. <tr> 
  93. <td>Johnson</td> 
  94. <td>Betty</td> 
  95. <td>5/12/1965</td> 
  96. <td>20nGy/h</td> 
  97. </tr> 
  98. <tr> 
  99. <td>Henderson</td> 
  100. <td>Nathan</td> 
  101. <td>10/15/1977</td> 
  102. <td>130nGy/h</td> 
  103. </tr> 
  104. <tr> 
  105. <td>Willianms</td> 
  106. <td>James</td> 
  107. <td>2/25/1949</td> 
  108. <td>10nGy/h</td> 
  109. </tr> 
  110. <tr> 
  111. <td>Gilliam</td> 
  112. <td>Michael</td> 
  113. <td>7/8/1980</td> 
  114. <td>140nGy/h</td> 
  115. </tr> 
  116. <tr> 
  117. <td>Walker</td> 
  118. <td>Matthew</td> 
  119. <td>6/18/1981</td> 
  120. <td>103nGy/h</td> 
  121. </tr> 
  122. </tbody>  
  123. </table> 
  124. </form> 
  125. </body> 
  126. </html> 

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 丽水市| 江山市| 沐川县| 延安市| 惠州市| 远安县| 正阳县| 射洪县| 鄂伦春自治旗| 阿拉善盟| 北碚区| 双鸭山市| 始兴县| 黄冈市| 新宁县| 曲阜市| 冕宁县| 陇南市| 凤山县| 临沂市| 华阴市| 保靖县| 定州市| 桂阳县| 新晃| 赤峰市| 新乡县| 尼玛县| 广丰县| 盐池县| 章丘市| 沐川县| 房产| 惠安县| 济宁市| 木兰县| 股票| 措美县| 仙游县| 女性| 集贤县|