大佬教程收集整理的这篇文章主要介绍了jquery – 排序(按字母顺序)以忽略空单元格:dataTables,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我尝试了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 == " ") 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; }
用:
$(document).ready(function() { $('#classement').dataTable({ "aocolumns": [ null,null,{ "type" : "myString" },null ] } ); } );
有一个像|的表N°|编辑|宋|歌手|网址|
仅对歌曲和歌手进行排序.
emty单元位于底部(正如预期的那样),但现在排序没有逻辑(没有字母顺序,我应该在dataTable中使用另一个属性吗?).
有没有人有办法解决吗?
编辑:如果我们动态添加一行,如何刷新排序?
$("#example").find('tbody') .append($('<tr>') .append($('<td>') .text('Boro') ) );
我认为aocolumns对于DataTables v 1.9来说是legacy option.话虽这么说,您可能还需要使用$.extend来包含您的自定义排序功能.
请查看下面的Stack Snippet,或者在jsfiddle上的这个现场演示.简而言之,我在表格初始化期间将name列定义为非空字符串类型.然后我使用非空字符串asc和非空字符串-desc排序函数扩展了jQuery.fn.dataTableExt.oSort API.看看这是否是你要找的.
Stack Snippet:
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" 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>
以上是大佬教程为你收集整理的jquery – 排序(按字母顺序)以忽略空单元格:dataTables全部内容,希望文章能够帮你解决jquery – 排序(按字母顺序)以忽略空单元格:dataTables所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。