Reinitialise Datatable
Solution 1:
Updated with explanation and references
There is no need separate Ajax request. Stick with Datatables Ajax option is enough.
We can use Datatables ajax.data option to add additional data
to the request, or to modify the data object
being submitted to server if required.
To work with new and refresh data input
we need to use ajax.data as a function
otherwise it will initialized as a static object which will evaluated only once.
var table = $('#example').dataTable( {
"ajax": {
"url": "data.json",
"data": function ( data) {
//your data altering codes
}
}
} );
And then use Datatables ajax.reload() to reload the table data from the Ajax data source within your event calls.
Possible ways to update data request using Datatables ajax.data is by:
- Using element value directly
var table = $('#example').dataTable({
"ajax": {
"url": "data.json",
"data": function(data) {
data.status = $('#status').val();
}
}
});
table.ajax.reload();
- Using global variable that can be changed inside event call before Datatables ajax.reload()
var global_status = 1;
var table = $('#example').dataTable({
"ajax": {
"url": "data.json",
"data": function(data) {
data.status = global_status;
}
}
});
$("#status").on('change', function() {
global_status = $(this).val();
table.ajax.reload();
});
Sample demo:
$.mockjax({
url: "Response1.php",
response: function(settings) {
// Investigate the `settings` to determine the response...if (settings.data.status == 1) {
this.responseText = {
"draw": settings.data.draw,
"recordsTotal": 57,
"recordsFiltered": 57,
"data": [
[
"Airi",
"Satou",
"Accountant",
"Tokyo",
"28th Nov 08",
"1"
],
[
"Angelica",
"Ramos",
"Chief Executive Officer (CEO)",
"London",
"9th Oct 09",
"1"
],
[
"Ashton",
"Cox",
"Junior Technical Author",
"San Francisco",
"12th Jan 09",
"1"
],
[
"Bradley",
"Greer",
"Software Engineer",
"London",
"13th Oct 12",
"1"
],
[
"Brenden",
"Wagner",
"Software Engineer",
"San Francisco",
"7th Jun 11",
"1"
],
[
"Brielle",
"Williamson",
"Integration Specialist",
"New York",
"2nd Dec 12",
"1"
],
[
"Bruno",
"Nash",
"Software Engineer",
"London",
"3rd May 11",
"1"
],
[
"Caesar",
"Vance",
"Pre-Sales Support",
"New York",
"12th Dec 11",
"1"
],
[
"Cara",
"Stevens",
"Sales Assistant",
"New York",
"6th Dec 11",
"1"
],
[
"Cedric",
"Kelly",
"Senior Javascript Developer",
"Edinburgh",
"29th Mar 12",
"1"
]
]
}
}
if (settings.data.status == 0) {
this.responseText = {
"draw": settings.data.draw,
"recordsTotal": 57,
"recordsFiltered": 57,
"data": [
[
"Airi",
"Satou",
"Accountant",
"Tokyo",
"28th Nov 08",
"0"
],
[
"Angelica",
"Ramos",
"Chief Executive Officer (CEO)",
"London",
"9th Oct 09",
"0"
],
[
"Ashton",
"Cox",
"Junior Technical Author",
"San Francisco",
"12th Jan 09",
"0"
]
]
}
}
}
});
$(document).ready(function() {
var req_status = 1;
var table = $('#example').DataTable({
"processing": true,
"serverSide": true,
"paging": false,
"ordering": false,
"info": false,
"searching": false,
"ajax": {
"url": "Response1.php",
"type": "POST",
"data": function(data) {
data.status = req_status;
}
},
});
$("div.toolbar1").html('<select id="status" type="status"><option value="1">Active</option><option value="0">Inactive</option></select>');
$("#status").on('change', function() {
req_status = $(this).val();
table.ajax.reload();
console.log('Status Val',table.ajax.params().status);
});
});
<scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/jquery/2.1.4/jquery.min.js"></script><scriptsrc="https://cdnjs.cloudflare.com/ajax/libs/jquery-mockjax/1.6.2/jquery.mockjax.min.js"></script><scriptsrc="https://cdn.datatables.net/1.10.19/js/jquery.dataTables.min.js"></script><linkhref="https://cdn.datatables.net/1.10.19/css/jquery.dataTables.min.css" /><divclass="toolbar1"></div><tableid="example"class="display"style="width:100%"><thead><tr><th>First name</th><th>Last name</th><th>Position</th><th>Office</th><th>Start date</th><th>Status</th></tr></thead><tfoot><tr><th>First name</th><th>Last name</th><th>Position</th><th>Office</th><th>Start date</th><th>Status</th></tr></tfoot></table>
Solution 2:
Try this
$("#tb1").dataTable().fnDestroy();
$("#tb1").html(data);
$("#tb1").DataTable();
Solution 3:
Add this after serverside: true,
destroy:true
to destroy the table after its initialised
Solution 4:
Try using a single call
functioninitTable(tableId, apiUrl){
var table_element = "#" + tableId;
if ($.fn.DataTable.isDataTable(table_element )) {
//remove datatable framework on the table so we can re-initialize new record
$(table_element).DataTable().clear().destroy();
$(table_element).html(''); //empty the table entirely
}
//re-initialize tablevar table = $(table_element).DataTable({
"destroy": true,
"bprocessing": true,
"serverSide": true,
"ajax": {
"url": apiUrl,
"type": "POST",
"error": function(){
$("#grid_processing").css("display","none");
}
}
});
}
Call function from anywhere like this
initTable('tb1','./Response1.php');
Post a Comment for "Reinitialise Datatable"