首页 > 语言 > 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程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选