Ali*_*aly 8 javascript c# jquery datatables
我正试图data()从一个datatable内部有一个按钮的单元格中读取,但是我遇到了错误.
这是我的Datatable定义:
$("#example").DataTable({
destroy: true,
"columnDefs": [{
orderable: false,
targets: 0
}],
"columns": [
{
"data": "slno",
"fnCreatedCell": function (nTd, sData, oData, iRow, iCol) {
$(nTd).html('<a href="AddNewTicket.aspx?subjectID=' + oData.subjectID + '&subject_id=' + oData.subject_id + '&serviceID=' + oData.crm_services_id + '&severityID=' + oData.severityID + '&statusID=' + oData.statusID + '&callerID=' + '66355356' + '">' + oData.slno + '</a>');
},
},
{ "data": "status_message" },
{ "data": "crm_services_id" },
{ "data": "subject_id" },
{ "data": "severity_id" },
{"data": "user_id" },
{ "data": "status_id" },
{
"data": "caller_number",
"fnCreatedCell": function (nTd, sData, oData, iRow, iCol) {
$(nTd).html('<button class="btn btn-primary" id= "' + oData.subjectID + '">Call Customer</button>');
},
}
],
select: {
style: 'os',
selector: 'td:first-child'
},
"data": response,
"sDom": '<"top">tip'
});
Run Code Online (Sandbox Code Playgroud)
这是我正在尝试获取数据的地方:
var table = $("#example").DataTable();
$('#example tbody').on('click', 'button', function () {
var subjectID = $(this).attr('id');
var thisData = table.row($(this).parents('tr')).data();
var userID = thisData[7];
sendCallRequest(subjectID, userID);
});
Run Code Online (Sandbox Code Playgroud)
这是我得到的错误:
无法读取未定义的属性'_aData'(...)
有什么建议吗?
在重新分配按钮之前,请尝试解除对按钮的绑定:
var table = $("#example").DataTable();
$('#example tbody').off('click');
$('#example tbody').on('click', 'button', function () {
var subjectID = $(this).attr('id');
var thisData = table.row($(this).parents('tr')).data();
var userID = thisData[7];
sendCallRequest(subjectID, userID);
});
Run Code Online (Sandbox Code Playgroud)
为什么我建议这样做:我有一个非常类似的问题,其中DataTables无法调用rowReorder事件.我也通过AJAX /动态创建我的表(你似乎也做了),所以显然我的事件监听器(在我的情况下为table.on('row-reorder'))被多次绑定.在第一次删除事件监听器并读取它之后,我终于开始工作了.