重新创建数据表时,Jquery Datatable会出错:TypeError:t [c]未定义

时间:2016-07-24 02:50:38

标签: javascript jquery datatables

我有一个创建数据表的函数。在页面加载时,将创建并绘制数据表。现在,当我有一个表单提交以在表上进行搜索时,我调用相同的函数。首先我创建一个数据表的实例,我调用clear函数然后调用函数重新创建它。

以下是我第一次创建数据表的方法,其工作正常:

    $(window).load(function () {


        var table = UpdateTableCompany(null, null);
        .....

以下是管理数据表的功能:

    function UpdateTableCompany(val, search_field)
{
    $('#tablePubDev').DataTable().clear();
    var table = $('#tablePubDev').DataTable({
        destroy: true,
        searching: false,
        "lengthMenu": [[5, 10, 15, -1], [5, 10, 15, "All"]],
        "pageLength": 5,
        "columnDefs": [
            {
                "render": function (data, type, row) {


                    var text = '<div class="form-group">' +
                            '<div class="checkbox-nice center" style="cursor: default; height:100px;">' +
                            '<img  src="/application/assets/img/pub_devs/logos/' + row['c']['logo'] + '" style="max-height:100%; max-width: 100%;"/>' +
                            '</div>' +
                            '<div class="checkbox-nice text-center" style="cursor: default">' +
                            '<strong >Id: ' + pad(data, 11) + '</strong>' +
                            '</label>' +
                            '</div>' +
                            '</div>';


                    return text;
                },
                "targets": 0,
            },
            {
                "render": function (data, type, row) {


                    var text = '<div class="form-group">' +
                            '<div class="checkbox-nice center" style="cursor: default; height:100px;"><p class="center" style="font-size: 150%; font-weight: bold;">' +
                            row['c']['descr'] +
                            '</p></div>' +
                            '</div>';


                    return text;
                },
                "targets": 1,
            },
            {
                "render": function (data, type, row) {

                    var add_text1 = '';
                    var checked1 = '';
                    var add_text2 = '';
                    var checked2 = '';

                    if (data != null && data > 0) {

                        checked1 += 'checked="checked"';
                    } else
                        add_text1 += 'buttonDisabled ';

                    if (row['c']['developer'] != null && row['c']['developer'] > 0) {

                        checked2 += 'checked="checked"';
                    } else
                        add_text2 += 'buttonDisabled ';


                    var text = '<div class="form-group">' +
                            '<div class="checkbox-nice ' + add_text1 + '" style="cursor: default">' +
                            '<input type="checkbox" ' + checked1 + ' disabled="disabled" id="checkbox-1">' +
                            '<label for="checkbox-1">' +
                            'Publisher ' +
                            '</label>' +
                            '</div>' +
                            '<div class="checkbox-nice ' + add_text2 + '" style="cursor: default">' +
                            '<input type="checkbox" id="checkbox-2" ' + checked2 + ' disabled="disabled">' +
                            '<label for="checkbox-2">' +
                            'Developer' +
                            '</label>' +
                            '</div>' +
                            '</div>';


                    return text;
                },
                "targets": 3,
            },
            {
                "render": function (data, type, row) {
                    var text = '<td style="width: 20%;">' +
                            //'<a href="#" class="table-link">' +
                            //'<span class="fa-stack">' +
                            //'<i class="fa fa-square fa-stack-2x"></i>' +
                            //'<i class="fa fa-search-plus fa-stack-1x fa-inverse"></i>' +
                            //'</span>' +
                            //'</a>' +
                            '<a href="#" class="table-link updatePubDev" data-modal="modal-11">' +
                            '<span class="fa-stack">' +
                            '<i class="fa fa-square fa-stack-2x"></i>' +
                            '<i class="fa fa-pencil fa-stack-1x fa-inverse"></i>' +
                            '</span>' +
                            '</a>' +
                            '<span class="fa-stack table-link danger deletePubDev">' +
                            '<i class="fa fa-square fa-stack-2x"></i>' +
                            '<i class="fa fa-trash-o fa-stack-1x fa-inverse"></i>' +
                            '</span>' +
                            '</td>';


                    return text;
                },
                "targets": 4,
            }
        ],
        "columns": [
            {"data": "c.idpubdev", "name": "c.idpubdev"},
            {"data": "c.descr", "name": "c.descr"},
            {"data": "c.date_founded", "name": "c.date_founded"},
            {"data": "c.publisher", "name": "c.publisher"},
            {"data": "c.date_founded", "name": "c.date_founded"},
            {"data": "c.developer", "name": "c.developer", "visible": false, "searchable": false},
            {"data": "c.logo", "name": "c.logo", "visible": false, "searchable": false},

        ],
        "order": [[0, false], [1, 'asc'], [2, 'asc'], [3, 'asc']],

        "displayLength": 3,
        serverSide: true,
        "ajax":
                {
                    "url": "/pubdev/search/",
                    "type": "POST",
                    "data": function (d) {
                        if (val)
                            d.val = val;
                        if (search_field)
                            d.search_field = search_field;
                    }

                },
        error: function (request, status, error) {
            alert('Unable to update table contents');
            console.log(request);
            console.log(status);
            console.log(error);
        },

    });

    return table;
}

这里是提交执行搜索功能的表单:

 $("#search_form").submit(function (e) {
            e.preventDefault();

            var search_key = $.trim($('#val').val());
            var search_field = 'c.descr like ';

            table = $('#tablePubDev').DataTable();

            table.clear();

            table = UpdateTableCompany(search_field, search_key);

        });

我目前正在使用jquery版本v1.10.2的缩小格式 datatable的版本是1.10.4

这是我在控制台中遇到的错误 enter image description here

我尝试了一个实验:我没有在文档中加载数据表,所以我做了一个搜索提交来加载数据表,它工作了!当然,如果我进行第二次搜索,则会发生相同的错误,因此问题与数据表的重新创建有关。所有后端代码(php)都能正常工作并提供所需的结果。

这是html中的表格

 <div class="main-box no-header clearfix">
                    <div class="main-box-body clearfix">
                        <div class="table-responsive">
                            <table id="tablePubDev" class="table user-list table-hover">
                                <thead>
                                    <tr>
                                        <th>Company</th>
                                        <th>Name</th>
                                        <th><span>Listed Games</th>
                                        <th>Type</th>
                                        <th>Actions</th>
                                    </tr>
                                </thead>
                                <tbody>

                                </tbody>
                            </table>
                        </div>
                    </div>
                </div>

我尝试过使用未限定版本的datatable(v 1.10.12)并且我仍然没有错误但是现在它说了他的:

  

TypeError:headerCells [i]未定义

headerCells[i].style.width = column.sWidthOrig !== null && column.sWidthOrig !==...
    // Clone the table header and footer - we can't use the header / footer
        // from the cloned table, since if scrolling is active, the table's
        // real header and footer are contained in different table tags
        tmpTable.find('thead, tfoot').remove();
        tmpTable
            .append( $(oSettings.nTHead).clone() )
            .append( $(oSettings.nTFoot).clone() );

        // Remove any assigned widths from the footer (from scrolling)
        tmpTable.find('tfoot th, tfoot td').css('width', '');

        // Apply custom sizing to the cloned header
        **headerCells = _fnGetUniqueThs( oSettings, tmpTable.find('thead')[0]** ); <-- This is where the error occurs <--

        for ( i=0 ; i<visibleColumns.length ; i++ ) {
            column = columns[ visibleColumns[i] ];

            headerCells[i].style.width = column.sWidthOrig !== null && column.sWidthOrig !== '' ?
                _fnStringToCss( column.sWidthOrig ) :
                '';

            // For scrollX we need to force the column width otherwise the
            // browser will collapse it. If this width is smaller than the
            // width the column requires, then it will have no effect
            if ( column.sWidthOrig && scrollX ) {
                $( headerCells[i] ).append( $('<div/>').css( {
                    width: column.sWidthOrig,
                    margin: 0,
                    padding: 0,
                    border: 0,
                    height: 1
                } ) );
            }
        }

        // Find the widest cell for each column and put it 

更新:

我想我知道为什么会这样,虽然我仍然需要找到解决方法。当我在Datatable实例化中定义我的列时,恰好发生了这样的事情:

   "columns": [
            {"data": "c.idpubdev", "name": "c.idpubdev"},
            {"data": "c.descr", "name": "c.descr"},
            {"data": "c.date_founded", "name": "c.date_founded"},
            {"data": "c.publisher", "name": "c.publisher"},
            {"data": "c.date_founded", "name": "c.date_founded"},
            {"data": "c.developer", "name": "c.developer", "visible": false, "searchable": false},
            {"data": "c.logo", "name": "c.logo", "visible": false, "searchable": false},

这些必须与我在html页面中包含的表头一样多

                            <thead>
                                    <tr>
                                        <th>Company</th>
                                        <th>Name</th>
                                        <th><span>Listed Games</th>
                                        <th>Type</th>
                                        <th>Actions</th>
                                    </tr>
                                </thead>

在这种情况下,我有5个表头和7个数据列定义(两个有visible = false)。当我在一个较旧的项目中使用它们时,我所要做的就是将“visible”属性设置为false,这样它们就不会被映射到表头,但是在这里它似乎不起作用...为什么呢你认为那会发生吗?我有办法解决它吗?

3 个答案:

答案 0 :(得分:8)

好的,我实际上解决了这个问题!所以datatable.js插件中有一个bug(feature ??)。当它尝试自动扩展列时,它需要具有与定义的数据列一样多的标头。因此,如果您有7个列定义并且只定义了5个头,则代码将失败并显示空指针异常。解决此问题的一种方法是将autowidth参数设置为false(默认情况下为true)。

   function UpdateTableCompany(val, search_field)
    {

        var table = $('#tablePubDev').DataTable({
            'destroy': true,
            searching: false,
            'info': false,
            paging: true,
            retrieve: false,
            processing: true,
            "autoWidth": false, // This parameter must be set to false
          ......

通过执行此操作,您可以避免调用实际尝试执行自动宽度的功能。因此,通过避免这部分数据表代码,您将不会遇到所描述的错误。

答案 1 :(得分:0)

每次点击#search_form button,而不是重新创建表格, 你应该只重新加载表数据源。请尝试以下方法:

首先,让我们稍微改变你的功能,这样就不再用它来更新你的表了,而是创建它(它只会被调用一次)。 删除搜索参数,如下所示:

来自function UpdateTableCompany(val, search_field)

function UpdateTableCompany()

你可能也想重命名你的功能:

function CreateTableCompany() {
...

现在,在“ajax”功能中,更改获取值的方式。 让它获得动态的价值,如:

d.val = $('#val').val().trim();
d.search_field = $('#search_field').val().trim();

现在您需要在 load 范围之外创建table变量,以便可以从其他函数访问它:

var table;
$(window).load(function () {
    table = CreateTableCompany();
...

最后,删除提交功能的内容(e.preventDefault();除外)

它应该是这样的:

$("#search_form").submit(function (e) {
    e.preventDefault();
    table.ajax.reload();
});

我认为这样做会有所帮助。我希望它有所帮助。

答案 2 :(得分:0)

有时,由于thead和datatable列中的列数不同,可能会发生此错误。