我正在尝试使用下拉列表过滤 adatatable 列,我按照此处文档中的步骤操作:https://datatables.net/examples/api/multi_filter_select.html
然而,我的下拉菜单仍然没有出现在表格的页脚处,所以我想知道出了什么问题。表格初始化良好,显示搜索和分页,而不是下拉菜单。
这是我初始化表的方式:
//initialize datatable
myTbl = $('#myTbl').DataTable({
initComplete: function () {
this.api().columns().every( function () {
var column = this;
var select = $('<select><option value=""></option></select>')
.appendTo( $(column.footer()).empty() )
.on( 'change', function () {
var val = $.fn.dataTable.util.escapeRegex(
$(this).val()
);
column
.search( val ? '^'+val+'$' : '', true, false )
.draw();
} );
column.data().unique().sort().each( function ( d, j ) {
select.append( '<option value="'+d+'">'+d+'</option>' )
} );
} );
},
columnDefs: [ {
targets: [0]
}],
pageLength: 5,
language: {
search: '',
searchPlaceholder: "Search"
},
columns: [{
data: function(d) { return d['name']}
}]
});
这是我在 HTML 中声明表格的方式:
<table id="myTbl">
<thead>
<tr>
<th></th>
</tr>
</thead>
<tbody>
</tbody>
<tfoot>
<tr>
<th></th>
</tr>
</tfoot>
</table>
感谢您的帮助!
编辑 我设法找出问题所在,以防有人遇到同样的问题,我将“initComplete”更改为“drawCallback”,并在 tfoot 标记中添加了一个空行,现在可以使用了。