DataTables搜索特定列

Jef*_*mel 5 jquery datatables jquery-select2

我已经根据我的需要调整了以下网页,并添加了一些代码,因此它现在有select2下拉菜单而不是常规选择菜单(我更喜欢它).但是我无法弄清楚如何调整代码,因此我只能在特定列而不是每列上使用它.任何指导将不胜感激.

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();
    }
Run Code Online (Sandbox Code Playgroud)

此外 - 如果有一个隐藏'通用'搜索框的选项,我也想将它隐藏在顶部,只提供这些select2框.谢谢.

(编辑更新修复程序,因此select2将为每个下拉框初始化,最后一个未初始化)

dav*_*rad 5

你可以用columns([array]).代替

this.api().columns().every( function () {
Run Code Online (Sandbox Code Playgroud)

并且您只想在第1,2,5和6列上执行搜索:

this.api().columns([1,2,5,6]).every( function () {
Run Code Online (Sandbox Code Playgroud)

  • @JeffBSoloWookie,我认为大卫的意思是代替`this.api().columns().every(function(){`使用这个`this.api().列([1,2,5,6] ]).every(function(){`. (2认同)
  • 作为旁注; 我注意到我的最后一个Dropbox盒子不是select2盒子.我不得不移动`$(".searchs2")的位置.select2();`用于最后一个初始化.我将修改原始帖子以反映它. (2认同)