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

Posted

技术标签:

【中文标题】排序(字母顺序)以忽略空单元格:dataTables【英文标题】:Sorting (alphabetical order) to ignore empty cells : dataTables 【发布时间】:2014-11-14 16:39:23 【问题描述】:

所以这个问题已经被问到here,但是这个解决方案对我不起作用(我可能做错了什么)。我想按字母顺序(“type”:“natural”)对表格进行排序,但我希望空单元格位于底部(对于 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 | 这样的表 仅按歌曲和歌手排序。

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

有人有解决办法吗?

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

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

JsFiddle (use isim's one)

【问题讨论】:

把代码放在jsfiddle上就好了 【参考方案1】:

更新:嵌入式堆栈片段。

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

请查看下面的 Stack Snippet 或 jsfiddle 上的此现场演示。简而言之,我在表初始化期间将name 列定义为non-empty-string 类型。然后我用non-empty-string-ascnon-empty-string-desc 排序函数扩展了jQuery.fn.dataTableExt.oSort API。看看这是不是你要找的。​​p>

堆栈片段:

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();
<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" >
    <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>

【讨论】:

谢谢,其实它是工作的,它只是大写和小写默认不管理。你的例子给了我线索。另一个问题,如果我在示例中动态添加新行,则似乎该行不是通过排序直接处理的。见jsfiddle.net/Fanch/cbL9r757 @Fanch 您应该使用row().add() API 插入新行,然后调用draw() API。看看这个fiddle。 我正在使用这段代码,它工作得很好,但我想知道是否有办法告诉数据表将具有特定类的 视为空的。我有 有链接来添加丢失的信息,但数据表当然不会将其视为空的。而且我不能将 包装在 标记中。 这对于包含整数的列如何工作?您将如何合并 num 类型? 使用此辅助列排序数字的顺序不正确。例如,对于在降序中显示的主字段中的空值,辅助字段中的金额字段将按降序显示值。但是,当对应的 Primary Column 为 Null 并按降序排列时,我希望 Amount Column 仍然按升序排列。我该怎么办? 【参考方案2】:

忽略空行

包括https://cdn.datatables.net/plug-ins/1.10.25/sorting/absolute.js

var nameType = $.fn.dataTable.absoluteOrder( 
            // value can be a string or empty
            value: '',
            // postion top or bottom 
            position: 'bottom' // or top
         );
         
        
$('#mytable').DataTable(
            columnDefs: [
                 targets: 0, type: nameType 
            ]
        );

【讨论】:

【参考方案3】:

好的,我找到了第二个问题的解决方案,请参阅 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

【讨论】:

您应该使用row().add() API 插入新行,然后调用draw() API。看看这个fiddle。 谢谢,有用的信息 :) 我不能使用row.add(),因为我在初始化时使用空单元格设置表格,然后用户更新它们。也许我可以将row.indexes() 与更新指定行的函数一起使用。

以上是关于排序(字母顺序)以忽略空单元格:dataTables的主要内容,如果未能解决你的问题,请参考以下文章

NSSortDescriptor 在查看详细视图并返回后按字母顺序重新排序单元格

如何按字母顺序对表格视图单元格进行排序

使用 NSFetchRequest 按日期和单元格按时区字母顺序对部分进行排序

SQL 实例

在datatable中能把某字段按照首字母拼音顺序排列么?

按字母顺序排序时忽略变音符号