{hero}

ajax

Since: DataTables 1.10

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 for jQuery.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 supersedes fnServerParams from DataTables 1.9-.
  • dataSrc (ajax.dataSrc) - By default DataTables will look for the property data (or aaData 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 use ajax.dataSrc (above), or use ajax 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:

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.