过滤器下拉列表未显示在数据表上

时间:2021-07-07 03:01:21

标签: html jquery datatable

我正在尝试使用下拉列表过滤 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 标记中添加了一个空行,现在可以使用了。

0 个答案:

没有答案