javascript - 为html表格实现数字排序?

标签 javascript html sorting

谁能帮我修改这段代码以支持数字排序。目前它只支持按字母顺序排序,我自己不是 js 编写者,我在网上找到了这个。我只需要它来排序数字,而不是字母。

奖励:是否可以让它支持数字和字符串

这是按字母顺序排序的工作链接。 jsfiddle.net

谢谢。

function sortTable(table, col, reverse) {
    var tb = table.tBodies[0], // use `<tbody>` to ignore `<thead>` and `<tfoot>` rows
        tr = Array.prototype.slice.call(tb.rows, 0), // put rows into array
        i;
    reverse = -((+reverse) || -1);
    tr = tr.sort(function (a, b) { // sort rows
        return reverse // `-1 *` if want opposite order
            * (a.cells[col].textContent.trim() // using `.textContent.trim()` for test
                .localeCompare(b.cells[col].textContent.trim())
               );
    });
    for(i = 0; i < tr.length; ++i) tb.appendChild(tr[i]); // append each row in order
}

function makeSortable(table) {
    var th = table.tHead, i;
    th && (th = th.rows[0]) && (th = th.cells);
    if (th) i = th.length;
    else return; // if no `<thead>` then do nothing
    while (--i >= 0) (function (i) {
        var dir = 1;
        th[i].addEventListener('click', function () {sortTable(table, i, (dir = 1 - dir))});
    }(i));
}

function makeAllSortable(parent) {
    parent = parent || document.body;
    var t = parent.getElementsByTagName('table'), i = t.length;
    while (--i >= 0) makeSortable(t[i]);
}

window.onload = function () {makeAllSortable();};

最佳答案

这对字符串和数字都有效

if(!isNaN(a.cells[col].textContent) && !isNaN(b.cells[col].textContent))
        return reverse * ((+a.cells[col].textContent) - (+b.cells[col].textContent))
       return reverse // `-1 *` if want opposite order
            * (a.cells[col].textContent.trim() // using `.textContent.trim()` for test
                .localeCompare(b.cells[col].textContent.trim())
               );

https://jsfiddle.net/oqr0mjc6/3/

关于javascript - 为html表格实现数字排序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32480140/

相关文章:

javascript - D3 有向图节点为矩形

javascript - 如何将特定索引的数组分配给另一个嵌套数组?

javascript - 单击时如何使div淡出?

javascript - anchor 标签跳转以避免固定标题

algorithm - 映射排序索引

string - 将后缀按后缀数组排序有何意义?

algorithm - 最重要的对比最低有效基数排序

javascript 弹出 concat 不起作用

javascript - Postgres 更改顺序

javascript - jQuery/正则表达式 : remove all p tags