数据表单个列搜索(选择输入)中断了大小调整

时间:2019-11-23 05:15:17

标签: javascript jquery css datatables

我已经在DataTables上实现了以下代码,以启用使用选择输入Link的单个列搜索

$(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>' )
            } );
        } );
    }
} );

});

搜索下拉列表显示并正常工作,但是它们将列的大小锁定为下拉列表的最大大小。这将导致DataTable在屏幕外运行。尤其是在小屏幕上。

enter image description here

如果我删除搜索列的代码,一切都会按预期进行,那么当屏幕较小时,列将自动换行。

enter image description here

我试图像这样设置选择框的最大限制。

$(document.querySelector("#example > tfoot > tr > th:nth-child(2) > select").classList.add("maxinput"));

.maxinput{
max-width:400px !important}

但是,这似乎是一个糟糕的解决方案,因为我希望下拉菜单在较大的屏幕上能够较大

0 个答案:

没有答案