var  stIsIE = false ;
sorttable = {
  init : function (if  (arguments .callee .done ) return ;
    arguments .callee .done  = true ;
    if  (_timer) clearInterval (_timer);
    if  (!document .createElement  || !document .getElementsByTagName ) return ;
    sorttable.DATE_RE  = /^(\d\d?)[\/\.-](\d\d?)[\/\.-]((\d\d)?\d\d)$/ ;
    forEach (document .getElementsByTagName ('table' ), function (table ) {
      if  (table.className .search (/\bsortable\b/ ) != -1 ) {
        sorttable.makeSortable (table);
      }
    });
  },
  makeSortable : function (table ) {
    if  (table.getElementsByTagName ('thead' ).length  == 0 ) {
      the = document .createElement ('thead' );
      the.appendChild (table.rows [0 ]);
      table.insertBefore (the, table.firstChild );
    }
    if  (table.tHead  == null ) table.tHead  = table.getElementsByTagName ('thead' )[0 ];
    if  (table.tHead .rows .length  != 1 ) return ;
    sortbottomrows = [];
    for  (var  i = 0 ; i < table.rows .length ; i++) {
      if  (table.rows [i].className .search (/\bsortbottom\b/ ) != -1 ) {
        sortbottomrows[sortbottomrows.length ] = table.rows [i];
      }
    }
    if  (sortbottomrows) {
      if  (table.tFoot  == null ) {
        tfo = document .createElement ('tfoot' );
        table.appendChild (tfo);
      }
      for  (var  i = 0 ; i < sortbottomrows.length ; i++) {
        tfo.appendChild (sortbottomrows[i]);
      }
      delete  sortbottomrows;
    }
    headrow = table.tHead .rows [0 ].cells ;
    for  (var  i = 0 ; i < headrow.length ; i++) {
      if  (!headrow[i].className .match (/\bsorttable_nosort\b/ )) {
        mtch = headrow[i].className .match (/\bsorttable_([a-z0-9]+)\b/ );
        if  (mtch) {
          override = mtch[1 ];
        }
        if  (mtch && typeof  sorttable["sort_"  + override] == 'function' ) {
          headrow[i].sorttable_sortfunction  = sorttable["sort_"  + override];
        } else  {
          headrow[i].sorttable_sortfunction  = sorttable.guessType (table, i);
        }
        headrow[i].sorttable_columnindex  = i;
        headrow[i].sorttable_tbody  = table.tBodies [0 ];
        dean_addEvent (headrow[i], "click" , sorttable.innerSortFunction  = function (e ) {
          if  (this .className .search (/\bsorttable_sorted\b/ ) != -1 ) {
            sorttable.reverse (this .sorttable_tbody );
            this .className  = this .className .replace ('sorttable_sorted' ,
              'sorttable_sorted_reverse' );
            this .removeChild (document .getElementById ('sorttable_sortfwdind' ));
            sortrevind = document .createElement ('span' );
            sortrevind.id  = "sorttable_sortrevind" ;
            sortrevind.innerHTML  = stIsIE ? ' <font face="webdings">5</font>'  : ' ▴' ;
            this .appendChild (sortrevind);
            return ;
          }
          if  (this .className .search (/\bsorttable_sorted_reverse\b/ ) != -1 ) {
            sorttable.reverse (this .sorttable_tbody );
            this .className  = this .className .replace ('sorttable_sorted_reverse' ,
              'sorttable_sorted' );
            this .removeChild (document .getElementById ('sorttable_sortrevind' ));
            sortfwdind = document .createElement ('span' );
            sortfwdind.id  = "sorttable_sortfwdind" ;
            sortfwdind.innerHTML  = stIsIE ? ' <font face="webdings">6</font>'  : ' ▾' ;
            this .appendChild (sortfwdind);
            return ;
          }
          theadrow = this .parentNode ;
          forEach (theadrow.childNodes , function (cell ) {
            if  (cell.nodeType  == 1 ) {
              cell.className  = cell.className .replace ('sorttable_sorted_reverse' , '' );
              cell.className  = cell.className .replace ('sorttable_sorted' , '' );
            }
          });
          sortfwdind = document .getElementById ('sorttable_sortfwdind' );
          if  (sortfwdind) {
            sortfwdind.parentNode .removeChild (sortfwdind);
          }
          sortrevind = document .getElementById ('sorttable_sortrevind' );
          if  (sortrevind) {
            sortrevind.parentNode .removeChild (sortrevind);
          }
          this .className  += ' sorttable_sorted' ;
          sortfwdind = document .createElement ('span' );
          sortfwdind.id  = "sorttable_sortfwdind" ;
          sortfwdind.innerHTML  = stIsIE ? ' <font face="webdings">6</font>'  : ' ▾' ;
          this .appendChild (sortfwdind);
          row_array = [];
          col = this .sorttable_columnindex ;
          rows = this .sorttable_tbody .rows ;
          for  (var  j = 0 ; j < rows.length ; j++) {
            row_array[row_array.length ] = [sorttable.getInnerText (rows[j].cells [col]), rows[j]];
          }
          row_array.sort (this .sorttable_sortfunction );
          tb = this .sorttable_tbody ;
          for  (var  j = 0 ; j < row_array.length ; j++) {
            tb.appendChild (row_array[j][1 ]);
          }
          delete  row_array;
        });
      }
    }
  },
  guessType : function (table, column ) {
    sortfn = sorttable.sort_alpha ;
    for  (var  i = 0 ; i < table.tBodies [0 ].rows .length ; i++) {
      text = sorttable.getInnerText (table.tBodies [0 ].rows [i].cells [column]);
      if  (text != '' ) {
        if  (text.match (/^-?[£$¤]?[\d,.]+%?$/ )) {
          return  sorttable.sort_numeric ;
        }
        possdate = text.match (sorttable.DATE_RE )
        if  (possdate) {
          first = parseInt (possdate[1 ]);
          second = parseInt (possdate[2 ]);
          if  (first > 12 ) {
            return  sorttable.sort_ddmm ;
          } else if  (second > 12 ) {
            return  sorttable.sort_mmdd ;
          } else  {
            sortfn = sorttable.sort_ddmm ;
          }
        }
      }
    }
    return  sortfn;
  },
  getInnerText : function (node ) {
    if  (!node) return "" ;
    hasInputs = (typeof  node.getElementsByTagName  == 'function' ) &&
      node.getElementsByTagName ('input' ).length ;
    if  (node.getAttribute ("sorttable_customkey" ) != null ) {
      return  node.getAttribute ("sorttable_customkey" );
    } else if  (typeof  node.textContent  != 'undefined'  && !hasInputs) {
      return  node.textContent .replace (/^\s+|\s+$/g , '' );
    } else if  (typeof  node.innerText  != 'undefined'  && !hasInputs) {
      return  node.innerText .replace (/^\s+|\s+$/g , '' );
    } else if  (typeof  node.text  != 'undefined'  && !hasInputs) {
      return  node.text .replace (/^\s+|\s+$/g , '' );
    } else  {
      switch  (node.nodeType ) {
        case 3 :
          if  (node.nodeName .toLowerCase () == 'input' ) {
            return  node.value .replace (/^\s+|\s+$/g , '' );
          }
        case 4 :
          return  node.nodeValue .replace (/^\s+|\s+$/g , '' );
          break ;
        case 1 :
        case 11 :
          var  innerText = '' ;
          for  (var  i = 0 ; i < node.childNodes .length ; i++) {
            innerText += sorttable.getInnerText (node.childNodes [i]);
          }
          return  innerText.replace (/^\s+|\s+$/g , '' );
          break ;
        default :
          return '' ;
      }
    }
  },
  reverse : function (tbody ) {
    
    newrows = [];
    for  (var  i = 0 ; i < tbody.rows .length ; i++) {
      newrows[newrows.length ] = tbody.rows [i];
    }
    for  (var  i = newrows.length  - 1 ; i >= 0 ; i--) {
      tbody.appendChild (newrows[i]);
    }
    delete  newrows;
  },
  sort_numeric : function (a, b ) {
    aa = parseFloat (a[0 ].replace (/[^0-9.-]/g , '' ));
    if  (isNaN (aa)) aa = 0 ;
    bb = parseFloat (b[0 ].replace (/[^0-9.-]/g , '' ));
    if  (isNaN (bb)) bb = 0 ;
    return  aa - bb;
  },
  sort_alpha : function (a, b ) {
    if  (a[0 ] == b[0 ]) return 0 ;
    if  (a[0 ] < b[0 ]) return  -1 ;
    return 1 ;
  },
  sort_ddmm : function (a, b ) {
    mtch = a[0 ].match (sorttable.DATE_RE );
    y = mtch[3 ];
    m = mtch[2 ];
    d = mtch[1 ];
    if  (m.length  == 1 ) m = '0'  + m;
    if  (d.length  == 1 ) d = '0'  + d;
    dt1 = y + m + d;
    mtch = b[0 ].match (sorttable.DATE_RE );
    y = mtch[3 ];
    m = mtch[2 ];
    d = mtch[1 ];
    if  (m.length  == 1 ) m = '0'  + m;
    if  (d.length  == 1 ) d = '0'  + d;
    dt2 = y + m + d;
    if  (dt1 == dt2) return 0 ;
    if  (dt1 < dt2) return  -1 ;
    return 1 ;
  },
  sort_mmdd : function (a, b ) {
    mtch = a[0 ].match (sorttable.DATE_RE );
    y = mtch[3 ];
    d = mtch[2 ];
    m = mtch[1 ];
    if  (m.length  == 1 ) m = '0'  + m;
    if  (d.length  == 1 ) d = '0'  + d;
    dt1 = y + m + d;
    mtch = b[0 ].match (sorttable.DATE_RE );
    y = mtch[3 ];
    d = mtch[2 ];
    m = mtch[1 ];
    if  (m.length  == 1 ) m = '0'  + m;
    if  (d.length  == 1 ) d = '0'  + d;
    dt2 = y + m + d;
    if  (dt1 == dt2) return 0 ;
    if  (dt1 < dt2) return  -1 ;
    return 1 ;
  },
  shaker_sort : function (list, comp_func ) {
    var  b = 0 ;
    var  t = list.length  - 1 ;
    var  swap = true ;
    while  (swap) {
      swap = false ;
      for  (var  i = b; i < t; ++i) {
        if  (comp_func (list[i], list[i + 1 ]) > 0 ) {
          var  q = list[i];
          list[i] = list[i + 1 ];
          list[i + 1 ] = q;
          swap = true ;
        }
      }
      t--;
      if  (!swap) break ;
      for  (var  i = t; i > b; --i) {
        if  (comp_func (list[i], list[i - 1 ]) < 0 ) {
          var  q = list[i];
          list[i] = list[i - 1 ];
          list[i - 1 ] = q;
          swap = true ;
        }
      }
      b++;
    }
  }
}
if  (document .addEventListener ) {
  document .addEventListener ("DOMContentLoaded" , sorttable.init , false );
}
if  (/WebKit/i .test (navigator.userAgent )) { var  _timer = setInterval (function (if  (/loaded|complete/ .test (document .readyState )) {
      sorttable.init (); 
    }
  }, 10 );
}
window .onload  = sorttable.init ;
function dean_addEvent (element, type, handler ) {
  if  (element.addEventListener ) {
    element.addEventListener (type, handler, false );
  } else  {
    if  (!handler.$$guid ) handler.$$guid  = dean_addEvent.guid ++;
    if  (!element.events ) element.events  = {};
    var  handlers = element.events [type];
    if  (!handlers) {
      handlers = element.events [type] = {};
      if  (element["on"  + type]) {
        handlers[0 ] = element["on"  + type];
      }
    }
    handlers[handler.$$guid ] = handler;
    element["on"  + type] = handleEvent;
  }
};
dean_addEvent.guid  = 1 ;
function removeEvent (element, type, handler ) {
  if  (element.removeEventListener ) {
    element.removeEventListener (type, handler, false );
  } else  {
    if  (element.events  && element.events [type]) {
      delete  element.events [type][handler.$$guid ];
    }
  }
};
function handleEvent (event ) {
  var  returnValue = true ;
  event = event || fixEvent (((this .ownerDocument  || this .document  || this ).parentWindow  || window ).event );
  var  handlers = this .events [event.type ];
  for  (var  i in  handlers) {
    this .$$handleEvent  = handlers[i];
    if  (this .$$handleEvent(event) === false ) {
      returnValue = false ;
    }
  }
  return  returnValue;
};
function fixEvent (event ) {
  event.preventDefault  = fixEvent.preventDefault ;
  event.stopPropagation  = fixEvent.stopPropagation ;
  return  event;
};
fixEvent.preventDefault  = function (this .returnValue  = false ;
};
fixEvent.stopPropagation  = function (this .cancelBubble  = true ;
}
if  (!Array .forEach ) {
  Array .forEach  = function (array, block, context ) {
    for  (var  i = 0 ; i < array.length ; i++) {
      block.call (context, array[i], i, array);
    }
  };
}
Function .prototype forEach  = function (object, block, context ) {
  for  (var  key in  object) {
    if  (typeof this .prototype "undefined" ) {
      block.call (context, object[key], key, object);
    }
  }
};
String .forEach  = function (string, block, context ) {
  Array .forEach (string.split ("" ), function (chr, index ) {
    block.call (context, chr, index, string);
  });
};
var  forEach = function (object, block, context ) {
  if  (object) {
    var  resolve = Object ;
    if  (object instanceof Function ) {
      resolve = Function ;
    } else if  (object.forEach instanceof Function ) {
      object.forEach (block, context);
      return ;
    } else if  (typeof  object == "string" ) {
      resolve = String ;
    } else if  (typeof  object.length  == "number" ) {
      resolve = Array ;
    }
    resolve.forEach (object, block, context);
  }
}Copy table .sortable thead  {
  background-color : #eee ;
  color : #666666 ;
  font-weight : bold;
  cursor : default;
}Copy <table class ="sortable" > <thead > <tr > <th > S.L.</th > <th > name</th > <th > Goal</th > </tr > </thead > <tbody > <tr > <td > 1</td > <td > Ronaldo</td > <td > 120</td > </tr > <tr > <td > 2</td > <td > Messi</td > <td > 66</td > </tr > <tr > <td > 3</td > <td > Ribery</td > <td > 10</td > </tr > <tr > <td > 4</td > <td > Bale</td > <td > 22</td > </tr > </tbody > </table > Copy 
Post a Comment for "Sorting Table Rows According To Table Header Column Using Javascript Or Jquery"