使用带有数据表的组合框过滤

时间:2019-07-19 09:38:39

标签: javascript datatables

我正在过滤单个表列的搜索选择输入。它正在工作,但我希望能够选择多个产品。

正常显示,如下所示:

initComplete: function () {
            this.api().columns().every( function () {
                var column = this;
                var select = $('<select style="width: 350px;"><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>' )
                } );
            } );
        }

但是现在我如何选择一个以上的产品,在html的{​​{1}}中放置select,但是过滤器也不再这样:

multiple

可以帮忙吗?

1 个答案:

答案 0 :(得分:1)

通常,可以使用OR搜索多个值。在正则表达式中,|是逻辑OR。因此,尝试使用join('|')

连接多个值

演示

var table = $('#example').DataTable({
  initComplete: function() {
    this.api().columns().every(function() {
      var column = this;
      var select = $('<select multiple><option value=""></option></select>')
        .appendTo($(column.footer()).empty())
        .on('change', function() {
          column
            .search($(this).val().map($.fn.dataTable.util.escapeRegex).join('|'), true, false)
            .draw();
        });

      column.data().unique().sort().each(function(d, j) {
        select.append('<option value="' + d + '">' + d + '</option>')
      });
    });
  }
})
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdn.datatables.net/1.10.19/js/jquery.dataTables.min.js"></script>
<link href="https://cdn.datatables.net/1.10.19/css/jquery.dataTables.min.css" rel="stylesheet" />


<table id="example" class="display" style="width:100%">
  <thead>
    <tr>
      <th>Name</th>
      <th>Position</th>
      <th>Office</th>
      <th>Numero</th>
      <th>Start date</th>
      <th>Salary</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>Tiger Nixon</td>
      <td>System Architect</td>
      <td>Edinburgh</td>
      <td>155555</td>
      <td>2011/04/25</td>
      <td>$320,800</td>
    </tr>
    <tr>
      <td>Garrett Winters</td>
      <td>Accountant</td>
      <td>Tokyo</td>
      <td>63</td>
      <td>2011/07/25</td>
      <td>$170,750</td>
    </tr>
    <tr>
      <td>Ashton Cox</td>
      <td>Junior Technical Author</td>
      <td>San Francisco</td>
      <td>1</td>
      <td>2009/01/12</td>
      <td>$86,000</td>
    </tr>
  </tbody>
  <tfoot>
    <tr>
      <td>Ashton Cox</td>
      <td>Junior Technical Author</td>
      <td>San Francisco</td>
      <td>1</td>
      <td>2009/01/12</td>
      <td>$86,000</td>
    </tr>
  </tfoot>
</table>