我正在尝试在数据表中按列进行过滤,但我不知道为什么只有在两列中存在该行时才会找到该行,我希望如果它在另一列中有搜索将找到结果。
我试过这样做,但是当我使用这个代码时,它只搜索第一列中的结果,例如。第四栏。而忽略了其余部分。
table.column([4,5]).search($(this).val()).draw();
$("#select-categories").each( function ( i ) {
var select = $('<select class="form-control"><option value="" class="optionGroup">Todas</option></select>')
.appendTo( $(this).empty() )
.on( 'change', function () {
table
.column(2).search( $(this).val() )
.draw();
});
documentosCatRef.on('value', function(data){
categoria = data.val();
for(var cat in categoria){
subcategoria = categoria[cat].subcategorias
select.append( '<option value="'+categoria[cat].titulo+'" class="optionGroup">'+categoria[cat].titulo+'</option>'+carregaSubcategoria(subcategoria)+'')
}
})
function carregaSubcategoria(subcategoria){
a = []
i = 0;
option = ""
for(var subcats in subcategoria){
a[i] = subcategoria[subcats].nome
i++
}
i = 0;
for (var subcat in a){
option += '<option value="'+a[subcat]+'"> '+a[subcat]+'</option>'
}
return option;
}
});
<div id="tableCustom_filter" class="dataTables_wrapper.no-footer dataTables_filter">
<label style="display: inline-block;">Filtrar por Categoria:</label>
<div style="display: inline-block;" id="select-categories"></div>
</div>