排序(按字母顺序)以忽略空单元格:dataTables

时间:2014-09-20 03:17:25

标签: jquery sorting datatables emptydatatext

所以问题已经被问到here,但解决方案对我不起作用(我可能做错了)。我想按字母顺序对表格进行排序("类型":"自然"),但我希望空单元格位于底部(对于desc和asc)。

我尝试了fbas提供的先前解决方案:

jQuery.fn.dataTableExt.oSort['mystring-asc'] = function(x,y) {
    var retVal;
    x = $.trim(x);
    y = $.trim(y);

    if (x==y) retVal= 0;
    else if (x == "" || x == " ") retVal=  1;
    else if (y == "" || y == " ") retVal=  -1;
    else if (x > y) retVal=  1;
    else retVal = -1;  // <- this was missing in version 1

    return retVal;
}
jQuery.fn.dataTableExt.oSort['mystring-desc'] = function(y,x) {
    var retVal;
    x = $.trim(x);
    y = $.trim(y);

    if (x==y) retVal= 0; 
    else if (x == "" || x == "&nbsp;") retVal=  -1;
    else if (y == "" || y == "&nbsp;") retVal=  1;
    else if (x > y) retVal=  1;
    else retVal = -1; // <- this was missing in version 1

    return retVal;
 }

使用:

$(document).ready(function() {
    $('#classement').dataTable({
    "aoColumns": [
        null,
        null,
        { "type" : "mystring" },
        { "type" : "mystring" },
        null
    ]
    } );
} );

使用| N° | Edit | Song | Singer | Url |这样的表格 仅对歌曲和歌手进行排序。

emty单元位于底部(正如预期的那样),但现在排序没有逻辑(没有字母顺序,我应该在dataTable中使用另一个属性吗?)。

有没有人有解决方案?

编辑:如果我们动态添加一行,如何刷新排序?

$("#example").find('tbody')
    .append($('<tr>')
        .append($('<td>')
                .text('Boro')
            )     
    );

JsFiddle (use isim's one)

2 个答案:

答案 0 :(得分:15)

更新:嵌入式网页摘要。

我认为aoColumns是DataTables v 1.9的legacy option。话虽这么说,您可能还需要使用$.extend来包含自定义排序功能。

请查看下面的Stack Snippet,或jsfiddle上的现场演示。简而言之,我在表初始化期间将name列定义为类型non-empty-string。然后,我使用jQuery.fn.dataTableExt.oSortnon-empty-string-asc排序函数扩展了non-empty-string-desc API。看看这是否是您正在寻找的。

Stack Snippet:

&#13;
&#13;
jQuery.extend( jQuery.fn.dataTableExt.oSort, {
    "non-empty-string-asc": function (str1, str2) {
        if(str1 == "")
            return 1;
        if(str2 == "")
            return -1;
        return ((str1 < str2) ? -1 : ((str1 > str2) ? 1 : 0));
    },
 
    "non-empty-string-desc": function (str1, str2) {
        if(str1 == "")
            return 1;
        if(str2 == "")
            return -1;
        return ((str1 < str2) ? 1 : ((str1 > str2) ? -1 : 0));
    }
} );


var dataTable = $('#example').dataTable({
    columnDefs: [
       {type: 'non-empty-string', targets: 0} // define 'name' column as non-empty-string type
    ]
});
dataTable.api().row.add(['John Smith', 'Intern', 'San Francisco', 19, 2011/05/25, 62000]).draw();
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="http://cdn.datatables.net/1.10.2/js/jquery.dataTables.min.js"></script>
<link href="http://cdn.datatables.net/1.10.2/css/jquery.dataTables.css" rel="stylesheet"/>

<table id="example" class="display" cellspacing="0" width="100%">
    <thead>
        <tr>
            <th>Name</th>
            <th>Position</th>
            <th>Office</th>
            <th>Age</th>
            <th>Start date</th>
            <th>Salary</th>
        </tr>
    </thead>
    <tbody>
        <tr>
            <td>Tiger Nixon</td>
            <td>System Architect</td>
            <td>Edinburgh</td>
            <td>61</td>
            <td>2011/04/25</td>
            <td>$320,800</td>
        </tr>
        <tr>
            <td>Garrett Winters</td>
            <td>Accountant</td>
            <td>Tokyo</td>
            <td>63</td>
            <td>2011/07/25</td>
            <td>$170,750</td>
        </tr>
        <tr>
            <td>Ashton Cox</td>
            <td>Junior Technical Author</td>
            <td>San Francisco</td>
            <td>66</td>
            <td>2009/01/12</td>
            <td>$86,000</td>
        </tr>
        <tr>
            <td>Cedric Kelly</td>
            <td>Senior Javascript Developer</td>
            <td>Edinburgh</td>
            <td>22</td>
            <td>2012/03/29</td>
            <td>$433,060</td>
        </tr>
        
        <tr>
            <td></td>
            <td>Junior Technical Author</td>
            <td>San Francisco</td>
            <td>66</td>
            <td>2009/01/12</td>
            <td>$86,000</td>
        </tr>
        <tr>
            <td></td>
            <td>Senior Javascript Developer</td>
            <td>Edinburgh</td>
            <td>22</td>
            <td>2012/03/29</td>
            <td>$433,060</td>
        </tr>
        
    </tbody>
</table>
&#13;
&#13;
&#13;

答案 1 :(得分:0)

好的,我找到了第二个问题的解决方案,请参阅Here

因此,在我的ajax请求之前销毁dataTable并在成功时重建它:

    else{
        // Destroy dataTable
        $('#classement').dataTable().fnDestroy();
        $.ajax({
            type: "POST",
            url: "ajax.php",
            data: {},
            success: function(msg){
                // Reload dataTable with sorting
                $('#classement').dataTable({
                    columnDefs: [
                       {type: 'non-empty-string', targets: [2,3]} // define 'name' column as non-empty-string type
                    ]
                });
            }
        });
    }

示例:JsFiddle