I'm working on a collapsible dataTable. The row count feature of dataTable is counting the collapsible row also!
Here is my fiddle: https://jsfiddle.net/helloIndia/13kf5Lto/11/
Code: `
<div class="tab-content mt-5" id="myTabContent">
<div class="tab-pane fade show active" id="kt_tab_pane_all" role="tabpanel" aria-labelledby="kt_tab_pane_all">
<div class="Inner_kt_tableR">
<div class="Inner_kt_tableR_top">
<div class="row">
<div class="col-sm-6">
<div class="Inner_kt_tableR_top_inner">
<a href="javascript:void(0);" data-toggle="modal" data-target="#addstaffModal" class="form_brntnxd minwdth mrbtmklright">Add</a>
<a href="javascript:void(0);" class="form_brntnxd minwdth archiv mrbtmklright borbtn">Archive</a>
<a href="javascript:void(0);" class="form_brntnxd minwdth archiv mrbtmklright borbtn">Export</a>
<a href="javascript:void(0);" class="form_brntnxd minwdth borbtn mrbtmklright">Import</a>
<a href="javascript:void(0);" class="form_brntnxd minwdth borbtn" data-toggle="modal" data-target="#addfilterfModal">Filters • 3</a>
<div class="f_p_searchk"><input type="text" class="form-control" placeholder="Search"><i class="fas fa-search"></i></div>
</div>
</div>
<div class="col-sm-6">
<div class="cool_page_nitionsd_main">
<div class="cool_page_info" id="student_page_info"></div>
<div class="cool_page_nitionsd" id="student_page_nitionsd"></div>
<div class="cool_page_viewd" id="student_page_viewd"></div>
</div>
</div>
</div>
</div>
<div class="dt_kdtable forcheckqbox">
<!--begin: Datatable-->
<table class="table table-checkable setclose" id="allstudent_dt" style="border-collapse:collapse;">
<thead>
<tr>
<th class="dt-left" rowspan="1" colspan="1" style="width: 30px;">
<label class="checkbox checkbox-single">
<input type="checkbox" value="" class="group-checkable">
<span></span>
</label>
</th>
<th></th>
<th>Name</th>
<th>Status</th>
<th>Exp.</th>
<th>Level</th>
<th>Date Added</th>
<th>Last Contact</th>
<th> </th>
</tr>
</thead>
<tbody>
<tr>
<td>
<label class="checkbox checkbox-single">
<input type="checkbox" value="" class="group-checkable">
<span></span>
</label>
</td>
<td class="accordion-toggle collapsed " data-toggle="collapse" data-target="#demo1">
</td>
<td><a href=""> John Doe </a></td>
<td>Active</td>
<td>12/01/2020</td>
<td>100%</td>
<td>Oct 27, 2020</td>
<td>Dec 31, 2020</td>
<td>
<a href="">
<img src=""></a>
</td>
</tr>
<tr class="hide-table-padding">
<td colspan="9">
<div class="collapse set_format_clool_main accordian-body" id="demo1">
<table cellpadding="5" cellspacing="0" border="0" style="padding-left: 50px;">
<tbody>
<tr class="set_format_clool">
<td>Amount Paid</td>
<td>$ 1,500.00</td>
</tr>
<tr class="set_format_clool">
<td>Credits Paid</td>
<td>21 / 109</td>
</tr>
<tr class="set_format_clool">
<td>Expiration</td>
<td>June 2024</td>
</tr>
<tr class="set_format_clool">
<td>Email</td>
<td>[email protected]</td>
</tr>
<tr class="set_format_clool">
<td>Phone Number</td>
<td>(321) 456-7890</td>
</tr>
<tr class="set_format_clool">
<td>College</td>
<td>Community College</td>
</tr>
</tbody>
</table>
</div>
</td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
</tr>
<tr>
<td>
<label class="checkbox checkbox-single">
<input type="checkbox" value="" class="group-checkable">
<span></span>
</label>
</td>
<td class="accordion-toggle collapsed sorting_1" id="accordion2" data-toggle="collapse" data-target="#demo2">
</td>
<td><a href=""> William Santiago </a></td>
<td>Active</td>
<td>12/01/2020</td>
<td>100%</td>
<td>Oct 27, 2020</td>
<td>Dec 31, 2020</td>
<td>
<a href="">
<img src=""></a>
</td>
</tr>
<tr class="hide-table-padding">
<td colspan="9">
<div class="collapse set_format_clool_main accordian-body" id="demo2">
<table cellpadding="5" cellspacing="0">
<tbody>
<tr class="set_format_clool">
<td>Amount Paid</td>
<td>$ 1,500.00</td>
</tr>
<tr class="set_format_clool">
<td>Credits Paid</td>
<td>21 / 109</td>
</tr>
<tr class="set_format_clool">
<td>Expiration</td>
<td>June 2024</td>
</tr>
<tr class="set_format_clool">
<td>Email</td>
<td>[email protected]</td>
</tr>
<tr class="set_format_clool">
<td>Phone Number</td>
<td>(321) 456-7890</td>
</tr>
<tr class="set_format_clool">
<td>College</td>
<td>Community College</td>
</tr>
</tbody>
</table>
</div>
</td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
<td style="display: none;"></td>
</tr>
</tbody>
</table>
<!--end: Datatable-->
</div>
</div>
</div>
</div>`
JS:
var table = $('#allstudent_dt').DataTable({
"dom": 'tplis',
"language": {
"responsive": true,
"lengthMenu": "View _MENU_",
"info": "_END_ of _TOTAL_",
"paginate": {
"next": "Next",
"previous": "Prev"
}
},
"initComplete": function() {
$("#student_page_nitionsd").append($("#allstudent_dt_wrapper .dataTables_paginate"));
$("#student_page_viewd").append($("#allstudent_dt_wrapper .dataTables_length"));
$("#student_page_info").append($("#allstudent_dt_wrapper .dataTables_info"));
},
"columns": [{
"data": "id"
},
{
"orderable": false,
"data": null,
"defaultContent": '+'
}, {
"data": "name"
}, {
"data": "status"
}, {
"data": "grandex"
}, {
"data": "fundlevel"
}, {
"data": "dateadded"
}, {
"data": "lastcontact"
}, {
"data": "info"
}
],
"order": [
[1, 'asc']
],
});
$('#allstudent_dt tbody').on('click', function() {
var tr = $(this).closest('tr');
var row = table.row(tr);
if ($(this).attr('data-click-state') == 1) {
$(this).attr('data-click-state', 0);
$(this).css({
'background-repeat': 'no-repeat',
'background-attachment': 'center',
'background-position': 'center'
})
} else {
$(this).attr('data-click-state', 1);
$(this).css({
'background-repeat': 'no-repeat',
'background-attachment': 'center',
'background-position': 'center'
})
}
});
How to prevent the double row count?
I really advise you to have your data in a JSON object (you can also fetch it using the jQuery DataTable Ajax functionality), instead of having it on your HTML table.
Look at my example:
var jsonData = [
{
"id": "1",
"name": "John Doe",
"status": "Active",
"grandex": "12/01/2020",
"fundlevel": "100%",
"dateadded": "Oct 27, 2020",
"lastcontact": "Dec 31, 2020",
"info": {
"amount_paid": "$ 1,500.00",
"credits_paid": "21 / 109",
"expiration": "June 2024",
"email": "[email protected]",
"phone_number": "(321) 456-7890",
"college": "Community College",
}
},
{
"id": "2",
"name": "William Santiago",
"status": "Active",
"grandex": "12/01/2020",
"fundlevel": "100%",
"dateadded": "Oct 27, 2020",
"lastcontact": "Dec 31, 2020",
"info": {
"amount_paid": "$ 1,500.00",
"credits_paid": "21 / 109",
"expiration": "June 2024",
"email": "[email protected]",
"phone_number": "(321) 456-7890",
"college": "Community College",
}
}
];
var table = $('#allstudent_dt').DataTable({
"dom": 'tplis',
"language": {
"responsive": true,
"lengthMenu": "View _MENU_",
"info": "_END_ of _TOTAL_",
"paginate": {
"next": "Next",
"previous": "Prev"
}
},
"data": jsonData,
"initComplete": function() {
$("#student_page_nitionsd").append($("#allstudent_dt_wrapper .dataTables_paginate"));
$("#student_page_viewd").append($("#allstudent_dt_wrapper .dataTables_length"));
$("#student_page_info").append($("#allstudent_dt_wrapper .dataTables_info"));
},
"columns": [
{
"data": "id",
"orderable": false,
"render": function() {
var html = '<label class="checkbox checkbox-single">' +
'<input type="checkbox" value="" class="group-checkable">' +
'<span></span></label>';
return html;
}
},
{
"className": 'details-control',
"orderable": false,
"data": null,
"defaultContent": ''
},
{ "data": "name" },
{ "data": "status" },
{ "data": "grandex" },
{ "data": "fundlevel" },
{ "data": "dateadded" },
{ "data": "lastcontact" }
],
"order": [
[2, 'asc']
],
});
/* Formatting function for row details - modify as you need */
function format ( d ) {
// `d` is the original data object for the row
return '<table cellpadding="5" cellspacing="0" border="0" style="padding-left:50px;">'+
'<tr class="set_format_clool">'+
'<td>Amount Paid:</td>'+
'<td>' + d.info.amount_paid + '</td>' +
'</tr>' +
'<tr class="set_format_clool">'+
'<td>Credits Paid:</td>'+
'<td>' + d.info.credits_paid + '</td>' +
'</tr>' +
'<tr class="set_format_clool">'+
'<td>Expiration:</td>'+
'<td>' + d.info.expiration + '</td>' +
'</tr>' +
'<tr class="set_format_clool">'+
'<td>Email:</td>'+
'<td>' + d.info.email + '</td>' +
'</tr>' +
'<tr class="set_format_clool">'+
'<td>Phone Number:</td>'+
'<td>' + d.info.phone_number + '</td>' +
'</tr>' +
'<tr class="set_format_clool">'+
'<td>Colleger:</td>'+
'<td>' + d.info.college + '</td>' +
'</tr>' +
'</table>';
}
// Add event listener for opening and closing details
$('#allstudent_dt 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(row.data()) ).show();
tr.addClass('shown');
}
});
/*$('#allstudent_dt tbody').on('click', function() {
var tr = $(this).closest('tr');
var row = table.row(tr);
if ($(this).attr('data-click-state') == 1) {
$(this).attr('data-click-state', 0);
$(this).css({
'background-repeat': 'no-repeat',
'background-attachment': 'center',
'background-position': 'center'
})
} else {
$(this).attr('data-click-state', 1);
$(this).css({
'background-repeat': 'no-repeat',
'background-attachment': 'center',
'background-position': 'center'
})
}
});*/
td.details-control {
background: url('https://datatables.net/examples/resources/details_open.png') no-repeat center center;
cursor: pointer;
}
tr.shown td.details-control {
background: url('https://datatables.net/examples/resources/details_close.png') no-repeat center center;
}
<link href="https://cdn.datatables.net/1.10.21/css/jquery.dataTables.min.css" rel="stylesheet"/>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.4/jquery.min.js"></script>
<script src="https://cdn.datatables.net/1.10.21/js/jquery.dataTables.min.js"></script>
<div class="tab-content mt-5" id="myTabContent">
<div class="tab-pane fade show active" id="kt_tab_pane_all" role="tabpanel" aria-labelledby="kt_tab_pane_all">
<div class="Inner_kt_tableR">
<div class="Inner_kt_tableR_top">
<div class="row">
<div class="col-sm-6">
<div class="Inner_kt_tableR_top_inner">
<a href="javascript:void(0);" data-toggle="modal" data-target="#addstaffModal" class="form_brntnxd minwdth mrbtmklright">Add</a>
<a href="javascript:void(0);" class="form_brntnxd minwdth archiv mrbtmklright borbtn">Archive</a>
<a href="javascript:void(0);" class="form_brntnxd minwdth archiv mrbtmklright borbtn">Export</a>
<a href="javascript:void(0);" class="form_brntnxd minwdth borbtn mrbtmklright">Import</a>
<a href="javascript:void(0);" class="form_brntnxd minwdth borbtn" data-toggle="modal" data-target="#addfilterfModal">Filters • 3</a>
<div class="f_p_searchk"><input type="text" class="form-control" placeholder="Search"><i class="fas fa-search"></i></div>
</div>
</div>
<div class="col-sm-6">
<div class="cool_page_nitionsd_main">
<div class="cool_page_info" id="student_page_info"></div>
<div class="cool_page_nitionsd" id="student_page_nitionsd"></div>
<div class="cool_page_viewd" id="student_page_viewd"></div>
</div>
</div>
</div>
</div>
<div class="dt_kdtable forcheckqbox">
<!--begin: Datatable-->
<table id="allstudent_dt" class="table display table-checkable setclose" style="border-collapse:collapse;">
<thead>
<tr>
<th class="dt-left" rowspan="1" colspan="1" style="width: 30px;">
<label class="checkbox checkbox-single">
<input type="checkbox" value="" class="group-checkable">
<span></span>
</label>
</th>
<th></th>
<th>Name</th>
<th>Status</th>
<th>Exp.</th>
<th>Level</th>
<th>Date Added</th>
<th>Last Contact</th>
</tr>
</thead>
</table>
<!--end: Datatable-->
</div>
</div>
</div>
</div>`