数据表不创建某些行

时间:2018-09-20 13:32:59

标签: javascript jquery datatables

有没有创建特定行的回调?

这是我的数据表对象:

 $('#table').DataTable({
    dom: "t<'col-sm-5'i><'col-sm-7'p>",
    autoWidth: false,
    serverSide: true,
    aaSorting: [[8, 'desc']],
    beforeCreatedRow: function(row, data) {
        if ( data.field == "OFF" ) {
            // DON'T CREATE THIS ROW
        }
    },
    rowId: 'id',
    lengthChange: false,
    iDisplayLength: 10,
    columns: [
        {data: "column1"},
        {data: "column2"},
        {data: "column3"},
        {data: "column4"},
        {data: "column5"},
        {data: "column6"}
    ]
});

我仅以beforeCreatedRow事件为例。我不确定此事件是否存在。只是为了向您展示我的需求。

因此,如您所见,如果data.field的值为OFF,则无需创建行

2 个答案:

答案 0 :(得分:2)

您可以使用rowCallback这样的方法

var table = $('#table').DataTable({
   "rowCallback": function(row, data, index){
      if ( row.field == "OFF" ) {
         jQuery(row).hide();
      }
   }
});

更多详细信息here

答案 1 :(得分:2)

我不会在DOM中填充无用的行。不用隐藏它们,只需跳过它们:

ajax: {
  url: 'some/url/',
  dataSrc: function(d) {
    var data = d.filter(function(row) {
      if (row.field != "OFF") return row
    })
    return data
  }
}

您可以通过插入xhr.dt事件来删除dataSrc之前不需要的行

$('#example').on('xhr.dt', function(e, settings, json, xhr ) {
  json.data = json.data.filter(function(row) {
     if (row.field != 'OFF') return row
  })
})

在此处查看演示-> http://jsfiddle.net/g4h7950t/

注意:上面的示例使用{ data: [..] } src。简直就是我手上的东西。