有没有创建特定行的回调?
这是我的数据表对象:
$('#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,则无需创建行
答案 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。简直就是我手上的东西。