jquery - 数据表搜索特定列

标签 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();
    }

另外 - 如果有一个选项可以隐藏“通用”搜索框,我也想将其隐藏在顶部,并只提供这些 select2 框。谢谢。

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

最佳答案

您可以使用列([数组])。而不是

this.api().columns().every( function () {

并且您只想对第 1、2、5 和 6 列执行搜索:

this.api().columns([1,2,5,6]).every( function () {

关于jquery - 数据表搜索特定列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31304606/

相关文章:

javascript - 如何在初始化时过滤 jquery 数据表

jquery - 通过单击行内的按钮访问数据表中的数据

javascript - select2 在 form.submit 上清除多项选择(ruby on Rails)

javascript - Jquery - 如何从 div 标签复制选定的文本?

javascript - jQuery, Bootstrap 下拉列表问题

jquery - 数据表、计算列

javascript - javascript中是否有任何函数可以检测文档的更改?

javascript - 在 Select2 中设置文本值

JQuery DataTables - 发布后刷新表数据 - ColdFusion

复选框的 jQuery 验证插件 minLength