如何在jQuery Tablesorter中创建特定的排序函数?

use*_*581 4 jquery tablesorter

我正在使用jQuery Tablesorter的这个伟大版本:http://mottie.github.com/tablesorter/docs/index.html

一切都运作良好但现在我有这个问题:在我的表中,我有一个列包含篮球运动员的位置.因此,我希望逻辑上对该列进行排序:PG-SG-SF-PF-C.

我试图创建这个自定义排序功能 - 看看我的脚本,第2列:

$(document).ready(function() { 

    $(".stats").tablesorter({
            sortInitialOrder: 'desc',
            sortRestart: true,
            // Enable use of the characterEquivalents reference 
            sortLocaleCompare: false, 
            // if false, upper case sorts BEFORE lower case 
            ignoreCase: true,
            headers: { 
                0: { 
                        sortInitialOrder: 'asc'
                }, 
                1: { 
                        sortInitialOrder: 'asc'
                },
                2: { 
                        textSorter: function(a, b){ 
                            var positions = {
                                "PG": 0,
                                "SG": 10,
                                "SF": 20,
                                "PF": 30,
                                "C": 40
                            };
                            return ((positions[a] < positions[b]) ? -1 : ((positions[a] > positions[b]) ? 1 : 0)); 
                        },
                        sortInitialOrder: 'asc'
                }
            }
        }
    ); 

});
Run Code Online (Sandbox Code Playgroud)

但是,该列仍然按字母顺序排序,就像普通文本字符串(C-PF-PG-SF-SG)一样.

我哪里弄错了?我在Javascript中并不是特别强大所以它可能在排序功能中的某个地方.谢谢.

use*_*581 6

我想通过添加我自己的解析器来解决这个问题,就像它在这个问题中所示:使用JQuery Sorter插件对表中的图像和超链接列进行排序

我会复制我希望它工作的脚本,希望它可以帮助某人:

$(document).ready(function() { 

    $.tablesorter.addParser({
            // set a unique id 
            id: 'positions',
            is: function(s) {
                    // return false so this parser is not auto detected 
                    return false;
            },
            format: function(s) {
                    // format your data for normalization 
                    return s.toLowerCase()
                            .replace("pg", "d")
                            .replace("sg", "h")
                            .replace("sf", "m")
                            .replace("pf", "r")
                            .replace("c", "v");
            },
            // set type, either numeric or text 
            type: 'text'
    });     

    $(".stats").tablesorter({
            sortInitialOrder: 'desc',
            sortRestart: true,
            headers: { 
                0: { 
                        sortInitialOrder: 'asc'
                }, 
                1: { 
                        sortInitialOrder: 'asc'
                },
                2: { 
                        sorter: 'positions',
                        sortInitialOrder: 'asc'
                }
            }
        }
    );

});
Run Code Online (Sandbox Code Playgroud)