DataTables 搜索特定列
DataTables search on specific columns
我根据自己的需要调整了以下网页并添加了一些代码,因此它现在有 select2 个下拉菜单,而不是常规的 select 菜单(我更喜欢后者)。但是我一直无法弄清楚如何调整代码,因此我只能在特定列而不是每一列上使用它。任何指导将不胜感激。
http://datatables.net/examples/api/multi_filter_select.html(我改编的代码)
initComplete: function () {
this.api().columns().every( function () {
var column = this;
var select = $("<select class='searchs2'><option value=''></option></select>")
.appendTo( $(column.header()).append() )
.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>' )});
});
$(".searchs2").select2();
}
此外 - 如果有隐藏 'generic' 搜索框的选项,我也想将其隐藏在顶部并只提供这些 select2 个框。谢谢。
(编辑以更新修复,因此 select2 将为每个下拉框初始化,最后一个未初始化)
您可以使用 columns([array])
。而不是
this.api().columns().every( function () {
并且您只想在第 1、2、5 和 6 列上执行搜索:
this.api().columns([1,2,5,6]).every( function () {
我根据自己的需要调整了以下网页并添加了一些代码,因此它现在有 select2 个下拉菜单,而不是常规的 select 菜单(我更喜欢后者)。但是我一直无法弄清楚如何调整代码,因此我只能在特定列而不是每一列上使用它。任何指导将不胜感激。
http://datatables.net/examples/api/multi_filter_select.html(我改编的代码)
initComplete: function () {
this.api().columns().every( function () {
var column = this;
var select = $("<select class='searchs2'><option value=''></option></select>")
.appendTo( $(column.header()).append() )
.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>' )});
});
$(".searchs2").select2();
}
此外 - 如果有隐藏 'generic' 搜索框的选项,我也想将其隐藏在顶部并只提供这些 select2 个框。谢谢。
(编辑以更新修复,因此 select2 将为每个下拉框初始化,最后一个未初始化)
您可以使用 columns([array])
。而不是
this.api().columns().every( function () {
并且您只想在第 1、2、5 和 6 列上执行搜索:
this.api().columns([1,2,5,6]).every( function () {