2

我正在使用 1.10.2 DataTables,我想利用 columnFilter 插件而不是手动将某些东西拼凑在一起。我正在使用带有数据表、jQuery 1.10.2、jQuery UI 1.10.3 和 bootstrap 3.1.1 的引导渲染器。这个特定的表不使用任何花哨的东西(没有固定的标题、没有固定的列、没有 ColVis 或 ColReorder)。分页已打开。

<link rel="stylesheet" type="text/css" href="~/CSS/dataTables.bootstrap.css" />
<!-- stuff -->
<table id="reportTable" class="table table-condensed table-striped table-bordered">
    <thead>
    </thead>
    <tbody>
    </tbody>
</table>
<!-- stuff -->
<script type='text/javascript' src='~/Scripts/jquery.dataTables.js'></script>
<script type='text/javascript' src='~/Scripts/dataTables.bootstrap.js'></script>
<script type="text/javascript" src="~/Scripts/jquery.dataTables.columnFilter.js"></script>

JavaScript:

vm.table = $('#reportTable').DataTable({
    dom: 'rtipfl',
    autoWidth: false,
    info: true,
    lengthChange: true,
    lengthMenu: [ 10, 15, 20 ],
    displayLength: 10,
    pageLength: 10,
    ordering: true,
    orderMulti: true,
    orderClasses: true,
    order: [[ 2, "asc" ]],
    paging: true,
    pagingType: "full_numbers",
    renderer: "bootstrap",
    deferRender: true,
    processing: true,
    scrollX: false,
    scrollY: false,
    scrollCollapse: false,
    searching: true,
    columns: vm.columns,
    columnDefs: vm.columnDefs,
    data: vm.postingArray,
    initComplete: function (settings, json) {
        vm.attachTableEventHandlers();
    }
});

这是一个有 22 列的表。我注意到的第一件事是 columnFilter 示例只提到了 DataTables 的小写初始化,例如:

$('#blabla').dataTable().columnFilter();

如果我说

vm.table = $('#reportTable').DataTable({
     ...
}).columnFilter();

我长胖了

"TypeError: $(...).DataTable(...).columnFilter is not a function
 vm.table = $('#reportTable').DataTable({"

如果我说

vm.table = $('#reportTable').DataTable({
     ...
});
$('#reportTable').columnFilter();

"TypeError: oTable.fnSettings is not a function
if (!oTable.fnSettings().oFeatures.bFilter)"

如果我说

vm.table = $('#reportTable').DataTable({
     ...
});
$('#reportTable').dataTable().columnFilter();

没有过滤器出现。

我究竟做错了什么?我应该如何初始化它?

4

1 回答 1

5

我不认为您可以使用columnFilter新的“D”datables api 应用,因为与.dataTable()返回 jQuery 对象的调用不同,新.DataTable调用返回一个table对象。

您可以修补columnFilter以支持新的“D”api

或者

使用我的 yadcf 数据表插件为您的列添加过滤器

请注意,yadcf 支持新旧 api 的数据表,它有 10 种不同类型的过滤器和大量其他好东西 :)

github上的yadcf

yadcf展示

于 2014-12-18T10:48:03.743 回答