2012-04-01 81 views
1

我有兩個具有完全相同列的表。這些表格彼此相鄰放置。目前他們分開排序。我希望他們一起排序。即當我點擊表1的第一列標題時,兩個表都應該被排序,就好像它們都是單個表一樣。同時對兩個相似的表進行排序

這是我使用

function SortableTable (tableEl) { 

this.tbody = tableEl.getElementsByTagName('tbody'); 
this.thead = tableEl.getElementsByTagName('thead'); 
this.tfoot = tableEl.getElementsByTagName('tfoot'); 

this.getInnerText = function (el) { 
    if (typeof(el.textContent) != 'undefined') return el.textContent; 
    if (typeof(el.innerText) != 'undefined') return el.innerText; 
    if (typeof(el.innerHTML) == 'string') return el.innerHTML.replace(/<[^<>]+>/g,''); 
} 

this.getParent = function (el, pTagName) { 
    if (el == null) return null; 
    else if (el.nodeType == 1 && el.tagName.toLowerCase() == pTagName.toLowerCase()) 
     return el; 
    else 
     return this.getParent(el.parentNode, pTagName); 
} 

this.sort = function (cell) { 

    var column = cell.cellIndex; 
    var itm = this.getInnerText(this.tbody[0].rows[1].cells[column]); 
    var sortfn = this.sortCaseInsensitive; 

    if (itm.match(/\d\d[-]+\d\d[-]+\d\d\d\d/)) sortfn = this.sortDate; // date format mm-dd-yyyy 
    if (itm.replace(/^\s+|\s+$/g,"").match(/^[\d\.]+$/)) sortfn = this.sortNumeric; 

    this.sortColumnIndex = column; 

    var newRows = new Array(); 
    for (j = 0; j < this.tbody[0].rows.length; j++) { 
     newRows[j] = this.tbody[0].rows[j]; 
    } 

    newRows.sort(sortfn); 

    if (cell.getAttribute("sortdir") == 'down') { 
     newRows.reverse(); 
     cell.setAttribute('sortdir','up'); 
    } else { 
     cell.setAttribute('sortdir','down'); 
    } 

    for (i=0;i<newRows.length;i++) { 
     this.tbody[0].appendChild(newRows[i]); 
    } 

} 

this.sortCaseInsensitive = function(a,b) { 
    aa = thisObject.getInnerText(a.cells[thisObject.sortColumnIndex]).toLowerCase(); 
    bb = thisObject.getInnerText(b.cells[thisObject.sortColumnIndex]).toLowerCase(); 
    if (aa==bb) return 0; 
    if (aa<bb) return -1; 
    return 1; 
} 

this.sortDate = function(a,b) { 
    aa = thisObject.getInnerText(a.cells[thisObject.sortColumnIndex]); 
    bb = thisObject.getInnerText(b.cells[thisObject.sortColumnIndex]); 
    date1 = aa.substr(6,4)+aa.substr(3,2)+aa.substr(0,2); 
    date2 = bb.substr(6,4)+bb.substr(3,2)+bb.substr(0,2); 
    if (date1==date2) return 0; 
    if (date1<date2) return -1; 
    return 1; 
} 

this.sortNumeric = function(a,b) { 
    aa = parseFloat(thisObject.getInnerText(a.cells[thisObject.sortColumnIndex])); 
    if (isNaN(aa)) aa = 0; 
    bb = parseFloat(thisObject.getInnerText(b.cells[thisObject.sortColumnIndex])); 
    if (isNaN(bb)) bb = 0; 
    return aa-bb; 
} 

// define variables 
var thisObject = this; 
var sortSection = this.thead; 

// constructor actions 
if (!(this.tbody && this.tbody[0].rows && this.tbody[0].rows.length > 0)) return; 

if (sortSection && sortSection[0].rows && sortSection[0].rows.length > 0) { 
    var sortRow = sortSection[0].rows[0]; 
} else { 
    return; 
} 

for (var i=0; i<sortRow.cells.length; i++) { 
    sortRow.cells[i].sTable = this; 
    sortRow.cells[i].onclick = function() { 
     this.sTable.sort(this); 
     return false; 
    } 
} 

} 

的.js文件只是有兩列,並有可能保持不變。一些想法將非常感激。

+0

澄清:說表1的第一列是ID具有值1,3,5。表2具有相同的值,其值爲2,4。當單擊表1列標題時,應對這兩個表中的標識列進行排序。 T1將有1,2,3,而T2將有4,5。 – 2012-04-01 06:21:37

回答

0

我不太關注HTML(因爲您沒有包含任何HTML),所以我在這裏創建了一個簡單的版本,並在表中實現了一種排序。其基本思想是將表中的所有數據收集到單個JavaScript數據結構中,對javascript數據結構進行排序,然後將所有數據放回到表中。

這使得排序更簡單,並且唯一需要處理多個表的複雜性的地方是在檢索數據並將其放回表中時。你可以看到它在這裏工作:http://jsfiddle.net/jfriend00/Z5ywA/。只需點擊列標題即可查看按該列排序的兩個表。

的代碼是這樣的:

function sortTables(colNum) { 
    var t1 = document.getElementById("table1"); 
    var t2 = document.getElementById("table2"); 
    var data = [], sortFn; 

    function sortAlpha(a, b) { 
     // deal with empty strings 
     var aa = a[colNum].data, bb = b[colNum].data; 
     if (!aa) { 
      return(!bb ? 0 : -1); 
     } else if (!bb){ 
      return(1); 
     } else { 
      return(aa.localeCompare(bb)); 
     } 
    } 

    function sortNumeric(a, b) { 
     // deal with possibly empty strings 
     var aa = a[colNum].data, bb = b[colNum].data; 
     if (typeof aa == "string" || typeof bb == "string") { 
      return(sortAlpha(a, b)); 
     } else { 
      return(aa - bb); 
     } 
    } 

    // get the data 
    function getData(table) { 
     var cells, rowData, matches, item, cellData; 
     var rows = table.getElementsByTagName("tbody")[0].getElementsByTagName("tr"); 
     for (var i = 0; i < rows.length; i++) { 
      rowData = []; 
      cells = rows[i].getElementsByTagName("td"); 
      for (var j = 0; j < cells.length; j++) { 
       // add each cell in the row to the rowData data structure 
       item = {}; 
       item.origStr = cells[j].textContent || cells[j].innerText; 
       cellData = item.origStr.replace(/^\s*|\s*$/g, "").toLowerCase(); 
       if (cellData.match(/^[\d\.]+$/)) { 
        cellData= parseFloat(cellData); 
       } else if (matches = cellData.match(/^(\d+)-(\d+)-(\d+)$/)) { 
        cellData= new Date(
         parseInt(matches[3], 10), 
         parseInt(matches[1], 10) - 1, 
         parseInt(matches[2], 10) 
        ); 
       } 
       item.data = cellData; 
       // determine the type of sort based on the first cell we find 
       // with data in the column that we're sorting 
       if (!sortFn && item.data !== "" && j == colNum) { 
        if (typeof item.data == "number" || typeof item.data == "object") { 
         sortFn = sortNumeric; 
        } else { 
         sortFn = sortAlpha; 
        } 
       } 
       rowData.push(item); 
      } 
      // add each row to the overall data structure 
      data.push(rowData); 
     } 
    } 

    // put data back into the tables 
    function putData(table) { 
     var cells, rowData, item; 
     var rows = table.getElementsByTagName("tbody")[0].getElementsByTagName("tr"); 
     for (var i = 0; i < rows.length; i++) { 
      cells = rows[i].getElementsByTagName("td"); 
      for (var j = 0; j < cells.length; j++) { 
       // add each cell in the row to the rowData data structure 
       cells[j].innerHTML = data[0][j].origStr; 
      } 
      // remove this row 
      data.shift(); 
     } 
    } 


    getData(t1); 
    getData(t2); 
    data.sort(sortFn); 
    putData(t1); 
    putData(t2);   

    return(false); 
} 

+0

非常感謝!我會嘗試執行反向排序類似 – 2012-04-02 06:28:38

+0

@AbhishekMahale - 您可能會發現,將排序後的結果以相反的順序插入表中,而不是按相反的順序排序是最容易的。或者,您可以在插入它們之前在排序的結果上調用'.reverse()'。然後,您只需要一個簡單的地方來更改代碼,而不必影響每個排序例程。 – jfriend00 2012-04-02 14:36:04

相關問題