【问题标题】:Datables Searching / Filtering with rendered data使用渲染数据搜索/过滤数据表
【发布时间】:2015-08-20 02:10:11
【问题描述】:

我正在尝试使用选择框对 dataTables 表应用过滤。我发现以下代码允许我设置选择框并根据列数据进行过滤:

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

这段代码运行良好,但是我现在使用渲染方法将所有列合并为一个。我们这样做是为了给每一行设置样式以创建一个“票”。

不幸的是,现在过滤不起作用。我想这可能是列不再显示的结果,但希望得到一些指导和帮助:)

当前代码:

$('#ticket_list').DataTable( {

  "columnDefs": [
    {
        "render": function ( data, type, row ) {
            return '<span class="client-data"> ' + data + ' </span>' 
                + '<span class="priority-data"> ' + row[1] + ' </span>' 
                + '<span class="status-data"> ' + row[2] + ' </span>' 
                + '<div class="subject-data"> ' + row[3] + ' </div>'
                + '<i class="fa fa-user"></i><span class="agent-data"> ' + row[4] + ' </span>'
                + '<span class="date-data"> ' + row[5] + ' </span>';
        },
        "targets": 0
    },        
    { "visible": false, "targets": [ 1,2,3,4,5 ]}
    ],     
    "columns": [
        { "title": "" }
    ],
    "pageLength": setPageLength(),
    "dom": '<"#search-box"f> rt <"#pagination.col-xs-12"p> <"#table-information.col-xs-12"i>',
    language: {
        search: "_INPUT_",
        searchPlaceholder: "Search"
    },        
    initComplete: function () {
        this.api().columns([0,1,2]).every( function () {
            var column = this;
            var select = $('<select><option value=""></option></select>')
                .appendTo( ".ticket-filtering" )
                .on( 'change', function () {
                    var val = $.fn.dataTable.util.escapeRegex(
                        $(this).val()
                    );
                    console.log(val)
                    column
                        .search( val ? '^'+val+'$' : '', true, false )
                        .draw();
                } );

            column.data().unique().sort().each( function ( d, j ) {
                select.append( '<option value="'+d+'">'+d+'</option>' )
            } );
        } );
    },
} );

【问题讨论】:

    标签: javascript jquery datatables datatables-1.10


    【解决方案1】:

    原因

    render 函数无条件返回 HTML 字符串,而忽略 type 参数,但此函数用于获取数据用于多种用途:显示、排序、过滤、类型检测。

    解决方案

    render函数中使用类型检测,只在需要显示数据时返回HTML(type === 'display')。

    "render": function ( data, type, row ) {
       if(type === 'display'){
          data = '<span class="client-data"> ' + data + ' </span>' 
             + '<span class="priority-data"> ' + row[1] + ' </span>' 
             + '<span class="status-data"> ' + row[2] + ' </span>' 
             + '<div class="subject-data"> ' + row[3] + ' </div>'
             + '<i class="fa fa-user"></i><span class="agent-data"> ' + row[4] + ' </span>'
             + '<span class="date-data"> ' + row[5] + ' </span>';
       }
    
       return data;
    },
    

    演示

    有关代码和演示,请参阅 this jsFiddle

    【讨论】:

    猜你喜欢
    • 2017-05-05
    • 1970-01-01
    • 2012-11-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-04-01
    • 2012-12-04
    • 1970-01-01
    相关资源
    最近更新 更多