Как расширить таблицу детализации до третьего уровня в таблицах данных?
Я передал следующий код и успешно получил детализированную таблицу до двух уровней в таблицах данных.
https://jsfiddle.net/karlnicholas/2gc3r7vv/
Теперь я хочу получить таблицу детализации до 3-го уровня, поэтому я попытался расширить код, добавив кнопку управления деталями в дочернюю строку. пожалуйста, посмотрите в следующий код
<link rel="stylesheet" type="text/css" href="https://cdn.datatables.net/v/dt/dt-1.10.16/datatables.min.css"/>
<script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
<title>Datatable drilldown Example</title>
<link rel="stylesheet" type="text/css" href="http://ajax.aspnetcdn.com/ajax/jquery.dataTables/1.9.0/css/jquery.dataTables.css">
<link rel="stylesheet" type="text/css" href="http://ajax.aspnetcdn.com/ajax/jquery.dataTables/1.9.0/css/jquery.dataTables_themeroller.css">
<script type="text/javascript" charset="utf8" src="http://ajax.aspnetcdn.com/ajax/jquery.dataTables/1.9.0/jquery.dataTables.min.js"></script>
<script type="text/javascript" charset="utf8" src="https://cdn.datatables.net/1.10.11/js/jquery.dataTables.min.js"> </script>
<style>
td.details-control {
background: url('http://i.imgur.com/SD7Dz.png') no-repeat center center;
cursor: pointer;
}
tr.shown td.details-control {
background: url('http://i.imgur.com/SD7Dz.png') no-repeat center center;
}
td.details-control1 {
background: url('http://i.imgur.com/SD7Dz.png') no-repeat center center;
cursor: pointer;
}
tr.shown td.details-control1 {
background: url('http://i.imgur.com/SD7Dz.png') no-repeat center center;
}
</style>
<script>
var opinions = [{"id":47,"name":"E061140","fileName":null,"disposition":null,"summary":null,"title":"Marr. of Eustice","opinionDate":"2015-12-10"},{"id":48,"name":"C070296M","fileName":null,"disposition":null,"summary":null,"title":"P. v. Nilsson","opinionDate":"2015-12-10"},{"id":50,"name":"S209643","fileName":null,"disposition":null,"summary":null,"title":"P. v. Stevens","opinionDate":"2015-12-10"}];
var sections = [{"code":"code of civil procedure","sectionNumber":{"position":-1,"sectionNumber":"177.5"},"refCount":2,"section":{"part":"Chapter","partNumber":"4","title":"Incidental Powers and Duties of Judicial Officers","codeRange":{"sNumber":{"position":168,"sectionNumber":"177"},"eNumber":{"position":171,"sectionNumber":"179"}},"depth":3}},{"code":"code of civil procedure","sectionNumber":{"position":-1,"sectionNumber":"580"},"refCount":16,"section":{"part":"Chapter","partNumber":"1","title":"Judgment in General","codeRange":{"sNumber":{"position":862,"sectionNumber":"577"},"eNumber":{"position":879,"sectionNumber":"582.5"}},"depth":3}}];
function format ( table_id ) {
return '<table class="table table-striped" id="opiniondt_'+table_id+'">'+
'<thead><tr><th></th><th>References</th><th>Section</th><th>Statute Titles</th></tr></thead>'+
'<tr>'+
'<td id="table2"></td>'+
'<td>Full name:</td>'+
'<td>Extension number:</td>'+
'<td>Extra info:</td>'+
'</tr>'+
'<tr>'+
'<td id="table2"></td>'+
'<td>Full name:</td>'+
'<td>Extension number:</td>'+
'<td>Extra info:</td>'+
'</tr>'+
'</table>';
}
var iTableCounter=1;
var oInnerTable;
$(document).ready(function() {
TableHtml = $('#opiniondt').html();
var table = $('#opiniondt').DataTable( {
paging: false,
searching: false,
info: false,
rowId: 'id',
data: opinions,
columns:[
{ className: 'details-control',
orderable: false,
data: null,
defaultContent: '' },
{ data:'opinionDate'},
{ data:'title'},
{ data:'name'}
],
order: [[1, 'asc']]
} );
/* Add event listener for opening and closing details
* Note that the indicator for showing which row is open is not controlled by DataTables,
* rather it is done here
*/
$('#opiniondt tbody').on('click', 'td.details-control', function () {
var tr = $(this).closest('tr');
var row = table.row( tr );
if ( row.child.isShown() ) {
// This row is already open - close it
row.child.hide();
tr.removeClass('shown');
}
else {
// Open this row
row.child( format(iTableCounter) ).show();
tr.addClass('shown');
// try datatable stuff
oInnerTable = $('#opiniondt_' + iTableCounter).dataTable({
data: sections,
autoWidth: true,
deferRender: true,
info: false,
lengthChange: false,
ordering: false,
paging: false,
scrollX: false,
scrollY: false,
searching: false,
columns:[
{ className:'details-control1',
orderable: false,
data: null,
defaultContent: '' },
{ data:'refCount' },
{ data:'section.codeRange.sNumber.sectionNumber' },
{ data:'section.title' }
]
});
iTableCounter = iTableCounter + 1;
}
});
$('.2nddrill').click(function(){
console.log("class");
});
$('. details-control1').click(function(){
console.log("details-control1");
});
$('.even').click(function(){
console.log("even");
});
$('.odd').click(function(){
console.log("odd");
})
});
</script>
<table class="table table-striped table-bordered" id="opiniondt">
<thead><tr><th></th><th>Date</th><th>Title</th><th>Document</th></tr></thead>
У меня проблемы с получением события onclick для дочернего клика по строке. Я подумал, что так как details_control1 имеет то же имя класса, я мог бы использовать его для onclick, но это не сработало. Помогите мне с этой проблемой, заранее спасибо.