I am using DataTables with Bootstrap 4 and client side processing. Displaying around 2,000 records.
The loading time is acceptable, however I notice that when I reload the page (F5) I can see an un-formatted DataTable for a split second. It's almost as if DataTables is the last thing to load, and it's quite obvious.
If you look at their 'Zero configuration' example you can see what I mean. When reloading the page you can actually see all the table records for a split second (you have to be quick!).
There is a 'Bootstrap 4' example, also noticeable on that page.
I have a few questions;
I have tried re-ordering my JS and CSS files (I only have a few) however it has made no difference. My concern is that as I add more records the loading time will increase and the un-formatted DataTable will be more obvious on each page load.
This option allows DataTables to create the nodes (rows and cells in the table body) only when they are needed for a draw.
deferLoading is used to indicate that deferred loading is required, but it is also used to tell DataTables how many records there are in the full table (allowing the information element and pagination to be displayed correctly).
Show details. Number of rows to display on a single page when using pagination. If feature enabled (bLengthChange) then the end user will be able to override this to a custom setting using a pop-up menu.
Description. This event is fired when DataTables is doing some kind of processing - be it, sorting, filtering or any other kind of data processing. It can be used to indicate to the end user that there is something happening, or that something has finished.
Someone had the exact same issue. Seems to be pretty common, expesially with DT
See here for a good answer Datatables - on page load, table layout does not load instantly
In my opinion loading time cannot be acceptable for render 2000 rows(or more). Even if loading time is acceptable in PCs and laptops, there is problem for processing in mobiles. Did you test it already?
Datatable is a perfect plugin and has too many options. you can render just 10 rows in first view, and when the user want to see another pages, request from Datatable to draw and render them. So you need to use data property like this:
HTML:
<table id="example" class="table table-striped table-bordered" cellspacing="0">
<thead>
<tr>
<th>Name</th>
<th>Position</th>
<th>Office</th>
<th>Age</th>
<th>Start date</th>
<th>Salary</th>
</tr>
</thead>
<tbody>
</tbody>
</table>
JS:
var dataSet = new Array();
for(i=0;i<2000;i++){
var item = new Array(
"name "+i,
"position "+i,
"office "+i,
"age "+i,
"start date "+i,
"salary "+i
);
dataSet.push(item);
}
tableMain = $("#example").DataTable({
data: dataSet,
columns: [
{"orderable": true},
{"orderable": true},
{"orderable": true},
{"orderable": true},
{"orderable": true},
{"orderable": true}
],
pageLength: 10
});
As you see just 10 rows renders in HTML code via this method.
The hint is in the code of the Bootstrap 4 example you linked.
$(document).ready(function() {
$('#example').DataTable();
} );
This code states that when the document is ready (it has finished rendering HTML and CSS), take the element with the id example
and turn it into a DataTable.
To prevent this you could set the style of of the table to display: hidden
.
Then you can add $('#example').show()
to the code to display the table again after it has been made into a DataTable
$(document).ready(function() {
$('#example').DataTable();
$('#example').show();
} );
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With