将组合框放置到引导数据表头搜索字段

时间:2019-04-11 16:39:48

标签: javascript jquery datatable combobox bootstrap-4

我想将组合框放置在引导数据表标题中的搜索字段中。 https://datatables.net/examples/api/multi_filter_select.html 此链接使组合框不准确。 但我想将其放置在搜索字段中。

$(document).ready(function() {
    $('#example').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>' )
                } );
            } );
        }
    } );
} );

这是在此示例中使用的javascript代码。 我也可以将$(column.footer())。empty()更改为$(column.header()) 但它显示的是这样的https://imgur.com/a/92audmz

如该图所示,组合框位于标题中,但我想将其置于“名称”下方,表示用“搜索名称”输入字段替换。 请帮我!!!!! 谢谢您阅读我的问题。

1 个答案:

答案 0 :(得分:1)

我解决了我的问题。 用代码更改

.appendTo( $(column.footer()).empty() )

.appendTo(column.context[0].nTHead.childNodes[3].childNodes[1])

这表示我想要的那个单元格。