使用jQuery表orter排除列的排序

内容来源于 Stack Overflow,并遵循CC BY-SA 3.0许可协议进行翻译与使用

  • 回答 (2)
  • 关注 (0)
  • 查看 (98)

我正在寻找一种方法来排除使用jQuery的tablesorter插件对单个列进行排序。具体来说,我有一个相当大的表,并且希望保持一个“行号”列的固定,以便在排序后很容易看到表中某一行的位置。

例如:

#    name
-----------
1    papaya
2    apple
3    strawberry
4    banana

在Name列上排序时,应该会导致:

#    name
-----------
1    apple
2    banana
3    papaya
4    strawberry
提问于
用户回答回答于

下面是一个你可以使用的小部件,它可以完成你要寻找的内容:

$(function() {
    // add new widget called indexFirstColumn
    $.tablesorter.addWidget({
        // give the widget a id
        id: "indexFirstColumn",
        // format is called when the on init and when a sorting has finished
        format: function(table) {               
            // loop all tr elements and set the value for the first column  
            for(var i=0; i < table.tBodies[0].rows.length; i++) {
                $("tbody tr:eq(" + i + ") td:first",table).html(i+1);
            }                                   
        }
    });

    $("table").tablesorter({
        widgets: ['zebra','indexFirstColumn']
    });

});
用户回答回答于

对于那些在寻找将列排除为可排序(即列上可点击的标题)的方法时发现这一点的人,下面的示例将第4列(零索引)排除在排序之外:

$("table").tablesorter({
    headers: {4: {sorter: false}}
});

扫码关注云+社区

领取腾讯云代金券