javascript operates on table sort instance analysis

  • 2020-06-07 04:01:21
  • OfStack

This article gives an example of how javascript operates table sorting. Share to everybody for everybody reference. The details are as follows:

Complete examples are as follows:

 <title>Table Sort Example</title>
 <script type="text/javascript">
 // Converter, which converts the field type of a column to a sortable type: String,int,float
  function convert(sValue, sDataType) {
  switch(sDataType) {
   case "int":
   return parseInt(sValue);
   case "float":
   return parseFloat(sValue);
   case "date":
   return new Date(Date.parse(sValue));
   return sValue.toString();
  // The sort function generator, iCol Represents the column index, sDataType Represents the data type of the column 
  function generateCompareTRs(iCol, sDataType) {
  return function compareTRs(oTR1, oTR2) {
    var vValue1 = convert(oTR1.cells[iCol].firstChild.nodeValue, sDataType);
    var vValue2 = convert(oTR2.cells[iCol].firstChild.nodeValue, sDataType);
    if (vValue1 < vValue2) {
    return -1;
    } else if (vValue1 > vValue2) {
    return 1;
    } else {
    return 0;
  // Sorting method 
  function sortTable(sTableID, iCol, sDataType) {
  var oTable = document.getElementById(sTableID);
  var oTBody = oTable.tBodies[0];
  var colDataRows = oTBody.rows;
  var aTRs = new Array;
  // Put all the columns in the array 
  for (var i=0; i < colDataRows.length; i++) {
   aTRs[i] = colDataRows[i];
  // Determine the final 1 Whether the columns that are sorted are the same as the columns that are sorted now, 
  // If yes, use it directly reverse() The reverse 
  if (oTable.sortCol == iCol) {
  } else {
   // Array-Using sort Method, passed into the sort function 
   aTRs.sort(generateCompareTRs(iCol, sDataType));
  var oFragment = document.createDocumentFragment();
  for (var i=0; i < aTRs.length; i++) {
  // Record the last 1 Subsorted column index 
  oTable.sortCol = iCol;
 <p>Click on the table header to sort in ascending order.</p>
 <table border="1" id="tblSort">
   <th onclick="sortTable('tblSort', 0)"
   style="cursor:pointer">Last Name</th>
   <th onclick="sortTable('tblSort', 1)"
   style="cursor:pointer">First Name</th>
   <th onclick="sortTable('tblSort', 2, 'date')"
   <th onclick="sortTable('tblSort', 3, 'int')"

Hopefully, this article has been helpful in your javascript programming.

Related articles: