ajax
Load data for the table's content from an Ajax source.
Description
DataTables can obtain the data that it is to display in the table body from a number of sources, including from an Ajax data source, using this initialisation parameter. As with other dynamic data sources, arrays or objects can be used for the data source for each row, with columns.data
employed to read from specific object properties.
The ajax
property has three different modes of operation, depending on how it is defined. These are:
string
- Set the URL from where the data should be loaded from.object
- Define properties forjQuery.ajax
.function
- Custom data get function
.NET
It is common for the JSON payload to be wrapped as a string and returned enclosed in another JSON object as the d
parameter in .NET environments (some - not all!). As of DataTables 2.1, we handle this automatically, decoding the JSON string and using that as the intended payload.
Types
string
In its simplest form, ajax
, when given as a string will simply load the data from the given remote file. Note that DataTables expects the table data to be an array of items in the data
parameter of the object (use the ajax.dataSrc
option of ajax
as an object, if your data is formatted differently):
{
"data": [
// row 1 data source,
// row 2 data source,
// etc
]
}
DataTables can use objects or arrays in almost any format as the data source for each row through use of the columns.data
option. The default is to use an array data source.
Simple example:
new DataTable('#myTable', {
"ajax": "data.json"
} );
As of DataTables 2, this option can be given as an empty string to indicate to DataTables that it is an Ajax sourced table, but not to make an Ajax request until a URL is given, which can be done with ajax.url().load()
. This can be useful if you are using DataTables to display search results obtained by Ajax, for example.
object
As an object, the ajax
object is passed to jQuery.ajax allowing fine control of the Ajax request. DataTables has a number of default parameters which you can override using this option. Please refer to the jQuery documentation for a full description of the options available, although the following parameters provide additional options in DataTables or require special consideration:
data
(ajax.data
) - As with jQuery,data
can be provided as an object, but as an extension, it can also be provided as a function to manipulate the data DataTables sends to the server. The function takes a single parameter, an object where the parameters are name / value pairs that DataTables has readied for sending. An object may be returned which will be use used as the data to send to the server (therefore, if you wish to use the DataTables set parameters, you must merge them in your function), or you can add the items to the object that was passed in and not return anything from the function. This supersedesfnServerParams
from DataTables 1.9-.dataSrc
(ajax.dataSrc
) - By default DataTables will look for the propertydata
(oraaData
for compatibility with DataTables 1.9-) when obtaining data from an Ajax source or for server-side processing - this parameter allows that property to be changed, through two different forms:- As a string - define the property from the object to read. Note that if your Ajax source simply returns an array of data to display, rather than an object, set this parameter to be an empty string. Additionally you can use Javascript dotted object notation to get a data source for multiple levels of object / array nesting.
- As a function - As a function it takes a single parameter, the JSON returned from the server, which can be manipulated as required. The returned value from the function is what will be used by DataTables as the data source for the table.
- This supersedes
sAjaxDataProp
from DataTables 1.9-.
success
- Must not be overridden as it is used internally in DataTables. To manipulate / transform the data returned by the server useajax.dataSrc
(above), or useajax
as a function (below).
Simple example:
new DataTable('#myTable', {
"ajax": {
"url": "data.json",
"type": "POST"
}
} );
ajax( data, callback, settings )
As a function, making the Ajax call is left up to yourself allowing complete control of the Ajax request. Indeed, if desired, a method other than Ajax could be used to obtain the required data, such as Web storage or a Firebase database.
When the data has been obtained from the data source, the second parameter (callback
here) should be called with a single parameter passed in - the data to use to draw the table.
Simple example:
new DataTable('#myTable', {
"ajax": function (data, callback, settings) {
callback(
JSON.parse( localStorage.getItem('dataTablesData') )
);
}
} );
Note that as of DataTables 1.10.6 the xhr
event will be triggered when a function is used for ajax
(even if there is no Ajax request). Prior to 1.10.6 no event would have been triggered.
Parameters:
Name | Type | Optional | |
---|---|---|---|
1 | data | No | |
Data to send to the server | |||
2 | callback | No | |
Callback function that must be executed when the required data has been obtained. That data should be passed into the callback as the only parameter | |||
3 | settings | No | |
DataTables settings object |
Examples
Get JSON data from a file via Ajax.:
new DataTable('#myTable', {
ajax: 'data.json'
});
Get JSON data from a file via Ajax, using dataSrc
to change data
to tableData
(i.e. { tableData: [ ...data... ] }
):
new DataTable('#myTable', {
ajax: {
url: 'data.json',
dataSrc: 'tableData'
}
});
Get JSON data from a file via Ajax, using dataSrc
to read data from a plain array rather than an array in an object:
new DataTable('#myTable', {
ajax: {
url: 'data.json',
dataSrc: ''
}
});
Send request as POST:
new DataTable('#myTable', {
ajax: {
url: 'data.json',
type: 'POST'
}
});
Add data to the request, returnng an object by extending the default data:
new DataTable('#myTable', {
ajax: {
url: 'data.json',
data: function (d) {
return $.extend({}, d, {
extra_search: $('#extra').val()
});
}
}
});
Add data to the request by manipulating the data object:
new DataTable('#myTable', {
ajax: {
url: 'data.json',
data: function (d) {
d.extra_search = $('#extra').val();
}
}
});
Manipulate the data returned from the server - add a link to data (note this can, should, be done using render
for the column - this is just a simple example of how the data can be manipulated).:
new DataTable('#myTable', {
ajax: {
url: 'data.json',
dataSrc: function (json) {
for (var i = 0, ien = json.length; i < ien; i++) {
json[i][0] = '<a href="/message/' + json[i][0] + '>View message</a>';
}
return json;
}
}
});
Get the data from localStorage (could interface with a form for adding, editing and removing rows).:
new DataTable('#myTable', {
ajax: function (data, callback, settings) {
callback(JSON.parse(localStorage.getItem('dataTablesData')));
}
});
Related
The following options are directly related and may also be useful in your application development.