我有一个创建数据表的函数。在页面加载时,将创建并绘制数据表。现在,当我有一个表单提交以在表上进行搜索时,我调用相同的函数。首先我创建一个数据表的实例,我调用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
我尝试了一个实验:我没有在文档中加载数据表,所以我做了一个搜索提交来加载数据表,它工作了!当然,如果我进行第二次搜索,则会发生相同的错误,因此问题与数据表的重新创建有关。所有后端代码(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,这样它们就不会被映射到表头,但是在这里它似乎不起作用...为什么呢你认为那会发生吗?我有办法解决它吗?
答案 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列中的列数不同,可能会发生此错误。