Getting started with datatables

Other topics

Remarks:

Key features

  • Variable length pagination
  • On-the-fly filtering
  • Multi-column sorting with data type detection
  • Smart handling of column widths
  • Display data from almost any data source
  • DOM, JavaScript array, Ajax file and server-side processing
  • Scrolling options for table viewport
  • Fully internationalisable
  • jQuery UI ThemeRoller support
  • Wide variety of plug-ins
  • It's free

Resources

Additional Info:

VersionRelease notesRelease Date
1.9 and earlier (legacy)https://datatables.net/forums/discussion/8332/datatables-1-9-0-released2014-02-01
1.10 and laterhttps://datatables.net/new/1.102015-08-12

Installation

Have required JavaScript and CSS files included in your index.html. You can do this by either using the CDN files availiable at the following paths:

<link rel="stylesheet" type="text/css" href="//cdn.datatables.net/1.10.12/css/jquery.dataTables.css">
  
<script type="text/javascript" charset="utf8" src="//cdn.datatables.net/1.10.12/js/jquery.dataTables.js"></script>

Or by downloading individual local files and hosting them yourself. To get a comprehensive package of required JavaScript and CSS files visit the DataTables download builder which will allow you to pick and choose features you need and condense them into a single package (or offer individual files). Include these in the order displayed at the bottom of the page.

DataTables depends on jQuery, so include it before jquery.dataTables.js:

<script type="text/javascript" src="https://code.jquery.com/jquery-3.1.0.min.js"></script>

DataTables are also available through NPM

npm install datatables.net    # Core library
npm install datatables.net-dt # Styling

and Bower

bower install --save datatables.net
bower install --save datatables.net-dt

Initializing a minimal DataTables:

The below code will turn the table with an id of tableid into a DataTable, as well as return a DataTables API instance:

$(document).ready(function() {
    $('#tableid').DataTable();
});

Compare this to the below code, which will turn the table into a DataTable but will not return a DataTables API instance:

$(document).ready(function() {
    $('#tableid').dataTable();
});

See the DataTables API documentation section for more details on what can be done with the DataTables API instance.

Feature Enable/Disable (DataTables Options)

DataTables has the capability to enable or disable a number of its features, such as paging or searching. To choose these options, simply select them in your initialization:

$(document).ready(function() {
    $('#tableid').DataTable( {
        "paging":   false, //Turn off paging, all records on one page
        "ordering": false, //Turn off ordering of records
        "info":     false  //Turn off table information
    } );
} );

Note that the quotation marks around the option names are optional:

paging: false,
ordering: false,
info: false

Is also perfectly valid.

A full list of options can be found here, along with descriptions of the uses of each option.

These options can only be set once, when the table is initialised. However, you can work around this limitation by adding:

 destroy: true

DataTables API

DataTables comes with an extensive API which is used to manipulate or obtain information about the DataTables on a page.

The API can be accessed in 3 ways:

var table = $('#tableid').DataTable(); //DataTable() returns an API instance immediately
var table = $('#tableid').dataTable().api(); //dataTable() returns a jQuery object
var table = new $.fn.dataTable.Api('#tableid');

Once the object has been set, you can call any of the API functions on that object.

var columns = table.columns();

A more complex example is adding some rows to your table:

table.rows.add( [ {
        "name":       "John Doe",
        "employee_id":   "15135",
        "department":     "development",
    }, {
        "name":       "Jane Smith",
        "employee_id":   "57432",
        "department":     "quality assurance",
    } ] )
    .draw();

The full list of API functions can be found here.

Contributors

Topic Id: 1844

Example Ids: 6044,8288,12483,12484

This site is not affiliated with any of the contributors.