我在另一个页面上使用第二个DataTables对象时遇到问题。我已经成功创建了一个DataTable,它位于我的Web App中的页面上。它看起来很好,功能正常。然而,我然后复制了确切的代码并将其粘贴到第二页,虽然我的DataTable正确填充,但我得到了分页和搜索控件的第二个实例(如下所示)。我已经阅读了一些有关销毁表格的信息,因为可以检测到第二个实例,但我甚至尝试关闭我创建的第一个DataTable,它似乎并不重要。
加载我的DataTable是通过两个页面上的$(document).ready调用来完成的,虽然我不确定这是否正确,因为我想在同一页面上但在不同的选项卡控件中加载各种DataTable。 / p>
我的代码如下:
<script type="text/javascript" language="javascript" >
$(document).ready(function() {
var siteTickets = $('#ticketsTable').DataTable( {
"bProcessing": true,
"bServerSide": false,
"bDestroy": true,
"ajax":{
url :"framework/get_tickets_by_site.php"
},
aoColumns: [
{ mData: 'id', sClass: "dt-body-center" },
{ mData: 'summary',
"render" : function(data, type, row, meta){
return $('<a>')
.attr('href', data)
.text(data)
.wrap('<div></div>')
.parent()
.html();
}
},
{ mData: 'c_location', sClass: "dt-body-center",
"render" : function(data, type, row, meta){
return $('<a>')
.attr('href', data)
.text(data)
.wrap('<div></div>')
.parent()
.html();
}
},
{ mData: 'priority', sClass: "dt-body-center" },
{ mData: 'first_name', sClass: "dt-body-center" },
{ mData: 'created_at' },
{ mData: 'due_at' },
{ mData: 'status', sClass: "dt-body-center" },
{ mData: 'last_updated' }
],
"fnRowCallback": function (nRow, aData, iDisplayIndex, iDisplayIndexFull) {
switch( aData["priority"] ) {
case "1":
$("td:eq(3)", nRow).text( "High" );
break;
case "2":
$("td:eq(3)", nRow).text( "Medium" );
break;
case "3":
$("td:eq(3)", nRow).text( "Low" );
break;
default:
break;
}
return nRow;
},
"order": [[0, 'asc']],
"lengthMenu": [[20, 50, 100, -1], [20, 50, 100, "All"]]
} );
} );
</script>
我也尝试过使用DataTables.Destroy()
命令,但似乎没什么可行的。
任何帮助将不胜感激。感谢。
答案 0 :(得分:1)
DataTable实例化中有一个小错误。实例化DataTables的正确方法是使用小写字母selector.dataTable
,如下所示:
$('#ticketsTable').dataTable(...)
语法selector.DataTable()
用于DataTable API调用,例如:
$('#ticketsTable').DataTable().rows('.modified').invalidate().draw();
答案 1 :(得分:0)
可能该解决方案可以解决您的问题, 在表中将data-turbolinks设置为false
<table id="myTable" data-turbolinks="false">
/* Insert table content... */
</table>
如果您使用下面的代码创建数据表,
<script>
$(document).ready(function(){
$('#myTable').dataTable({ });
})
</script>