DataTables按钮+带下拉列的列过滤

时间:2016-05-19 18:03:28

标签: javascript jquery datatable

我目前有一个DataTable,其中包含我正在寻找的格式的数据下载按钮:

$(document).ready(function() {
$('#dataTables-example').DataTable( {
    dom: 'Bfrtip',
    buttons: [
        'copyHtml5',
        'excelHtml5',
        'csvHtml5',
        'pdfHtml5'
    ]
  } );
} );

但是,我希望能够在页脚中使用下拉菜单过滤列 - 与此链接中的示例完全相同:

https://datatables.net/examples/api/multi_filter_select.html

初始化代码为:

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

我想要的是结合这两个功能 - 列过滤器和数据下载选项。我尝试将按钮和dom片段移动到上面的代码中:

dom: 'Bfrtip',
    buttons: [
        'copyHtml5',
        'excelHtml5',
        'csvHtml5',
        'pdfHtml5'
    ]
  } );

但我没有运气让它显示正确(或根本没有)。

1 个答案:

答案 0 :(得分:0)

我有一个工程上的突破并做了显而易见的事情,之前添加了DOM设置:

initComplete: function(){.......

它有效。

完成功能:

$(document).ready(function() {

  $('#dataTables-example').DataTable( {
    dom: 'lBfrtip',
    buttons:  [
               'copyHtml5',
               'excelHtml5',
               'csvHtml5',
               'pdfHtml5'
               ],

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

});