2015-08-03 54 views
1

我需要爲包含正數和負數的特定列添加排序功能。在數據表jQuery中對負值和正值進行排序

默認情況下,排序按預期工作。但在我的情況下,我需要排序正值只。

柱:百分比

值: -1%16%2%12%0%

預期輸出: 升序:2%12%16%0% - 1%

降序排列:16%12%2%0%-1%

任何想法如何做排序這樣?

回答

0

您將需要創建一個自定義排序插件,自己做。你可以做如下的例子:

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% == -1
  2. 在後如果值< = 0

降序返回Number.NEGATIVE_INFINITY通過只值> 0,如果值< = 0

  • 上升返回Number.POSITIVE_INFINITY排序
    • 時包括在對列進行排序時。

  • 相關問題