1
我需要爲包含正數和負數的特定列添加排序功能。在數據表jQuery中對負值和正值進行排序
默認情況下,排序按預期工作。但在我的情況下,我需要排序正值只。
柱:百分比
值: -1%16%2%12%0%
預期輸出: 升序:2%12%16%0% - 1%
降序排列:16%12%2%0%-1%
任何想法如何做排序這樣?
我需要爲包含正數和負數的特定列添加排序功能。在數據表jQuery中對負值和正值進行排序
默認情況下,排序按預期工作。但在我的情況下,我需要排序正值只。
柱:百分比
值: -1%16%2%12%0%
預期輸出: 升序:2%12%16%0% - 1%
降序排列:16%12%2%0%-1%
任何想法如何做排序這樣?
您將需要創建一個自定義排序插件,自己做。你可以做如下的例子:
function ignoreZeroOrBelow(a, b, high) {
a = parseFloat(a);
a = a>0 ? a : high;
b = parseFloat(b);
b = b>0 ? b : high;
return ((a < b) ? -1 : ((a > b) ? 1 : 0));
}
jQuery.extend(jQuery.fn.dataTableExt.oSort, {
"sort-positive-numbers-only-asc": function (a, b) {
return ignoreZeroOrBelow(a, b, Number.POSITIVE_INFINITY);
},
"sort-positive-numbers-only-desc": function (a, b) {
return ignoreZeroOrBelow(a, b, Number.NEGATIVE_INFINITY)*-1;
}
});
用法:
var dataTable = $('#example').dataTable({
columnDefs: [
{ type: 'sort-positive-numbers-only', targets : 0 }
],
});
演示 - >http://jsfiddle.net/scuo0t6k/
插件背後的想法很簡單
-1%
== -1
)降序返回Number.NEGATIVE_INFINITY
通過只值> 0,如果值< = 0
Number.POSITIVE_INFINITY
排序