2013-10-16 13:13:30 +02:00
<!DOCTYPE html>
< html >
< head >
< meta charset = "utf-8" >
< link rel = "shortcut icon" type = "image/ico" href = "http://www.datatables.net/favicon.ico" >
2014-03-04 09:51:50 +01:00
< meta name = "viewport" content = "initial-scale=1.0, maximum-scale=2.0" >
2013-10-16 13:13:30 +02:00
< title > DataTables example - Automatic addition of row ID attributes< / title >
2013-12-19 15:04:37 +01:00
< link rel = "stylesheet" type = "text/css" href = "../../media/css/jquery.dataTables.css" >
2013-10-16 13:13:30 +02:00
< link rel = "stylesheet" type = "text/css" href = "../resources/syntax/shCore.css" >
< link rel = "stylesheet" type = "text/css" href = "../resources/demo.css" >
< style type = "text/css" class = "init" >
< / style >
2013-12-19 15:04:37 +01:00
< script type = "text/javascript" language = "javascript" src = "../../media/js/jquery.js" > < / script >
< script type = "text/javascript" language = "javascript" src = "../../media/js/jquery.dataTables.js" > < / script >
2013-10-16 13:13:30 +02:00
< script type = "text/javascript" language = "javascript" src = "../resources/syntax/shCore.js" > < / script >
< script type = "text/javascript" language = "javascript" src = "../resources/demo.js" > < / script >
< script type = "text/javascript" language = "javascript" class = "init" >
$(document).ready(function() {
$('#example').dataTable( {
"processing": true,
"serverSide": true,
"ajax": "scripts/ids-objects.php",
"columns": [
{ "data": "first_name" },
{ "data": "last_name" },
{ "data": "position" },
{ "data": "office" },
{ "data": "start_date" },
{ "data": "salary" }
]
} );
} );
< / script >
< / head >
< body class = "dt-example" >
< div class = "container" >
< section >
2014-03-14 13:32:46 +01:00
< h1 > DataTables example < span > Automatic addition of row ID attributes< / span > < / h1 >
2013-10-16 13:13:30 +02:00
< div class = "info" >
2014-12-11 16:27:11 +01:00
< p > Often when using server-side processing you will find that it can be useful to have a specific ID on each row (the primary key value from the database for
2015-06-04 16:26:45 +02:00
example). By assigning the ID you want to apply to each row using the property < code > DT_RowId< / code > of the data source object for each row (this property name can
2015-07-15 18:10:59 +02:00
be configured using the < a href = "//datatables.net/reference/option/idSrc" > < code class = "option" title = "DataTables initialisation option" > idSrc< / code > < / a > option),
DataTables will automatically add it for you (note that this will work for Ajax and Javascript loaded data as well as for server-side processing).< / p >
2013-10-16 13:13:30 +02:00
2015-06-04 16:26:45 +02:00
< p > In addition to < code > DT_RowId< / code > there are other properties which perform similar actions:< / p >
2013-10-16 13:13:30 +02:00
2014-04-25 14:27:28 +02:00
< ul class = "markdown" >
2015-06-04 16:26:45 +02:00
< li > {string} < code > DT_RowId< / code > - Add an ID to the < code class = "tag" title = "HTML tag" > tr< / code > element< / li >
< li > {string} < code > DT_RowClass< / code > - Add a class name to the < code class = "tag" title = "HTML tag" > tr< / code > element< / li >
< li > {object} < code > DT_RowData< / code > - Add HTML5 < em > data-< / em > attributes to the < code class = "tag" title = "HTML tag" > tr< / code > element. This is an object of
key / value pairs which are assigned as data attributes to the < code class = "tag" title = "HTML tag" > tr< / code > element.< / li >
< li > {object} < code > DT_RowAttr< / code > - Add attributes to the < code class = "tag" title = "HTML tag" > tr< / code > element. This is an object of key / value pairs which
are assigned as attributes to the < code class = "tag" title = "HTML tag" > tr< / code > element.< / li >
2013-10-16 13:13:30 +02:00
< / ul >
2014-12-11 16:27:11 +01:00
< p > This example below shows < code > DT_RowId< / code > being used to add information to the table. In addition objects are used as the data source for the rows.< / p >
2013-10-16 13:13:30 +02:00
< / div >
< table id = "example" class = "display" cellspacing = "0" width = "100%" >
< thead >
< tr >
2014-09-22 11:49:52 +02:00
< th > First name< / th >
< th > Last name< / th >
2013-10-16 13:13:30 +02:00
< th > Position< / th >
< th > Office< / th >
< th > Start date< / th >
< th > Salary< / th >
< / tr >
< / thead >
< tfoot >
< tr >
2014-09-22 11:49:52 +02:00
< th > First name< / th >
< th > Last name< / th >
2013-10-16 13:13:30 +02:00
< th > Position< / th >
< th > Office< / th >
< th > Start date< / th >
< th > Salary< / th >
< / tr >
< / tfoot >
< / table >
< ul class = "tabs" >
< li class = "active" > Javascript< / li >
< li > HTML< / li >
< li > CSS< / li >
< li > Ajax< / li >
2014-01-17 17:45:14 +01:00
< li > Server-side script< / li >
2013-10-16 13:13:30 +02:00
< / ul >
< div class = "tabs" >
< div class = "js" >
2014-12-11 16:27:11 +01:00
< p > The Javascript shown below is used to initialise the table shown in this example:< / p > < code class = "multiline language-js" > $(document).ready(function() {
2013-10-16 13:13:30 +02:00
$('#example').dataTable( {
" processing" : true,
" serverSide" : true,
" ajax" : " scripts/ids-objects.php" ,
" columns" : [
{ " data" : " first_name" },
{ " data" : " last_name" },
{ " data" : " position" },
{ " data" : " office" },
{ " data" : " start_date" },
{ " data" : " salary" }
]
} );
2013-12-19 15:03:24 +01:00
} );< / code >
2013-10-16 13:13:30 +02:00
2014-12-11 16:27:11 +01:00
< p > In addition to the above code, the following Javascript library files are loaded for use in this example:< / p >
2013-10-16 13:13:30 +02:00
< ul >
2013-12-19 15:04:37 +01:00
< li > < a href = "../../media/js/jquery.js" > ../../media/js/jquery.js< / a > < / li >
< li > < a href = "../../media/js/jquery.dataTables.js" > ../../media/js/jquery.dataTables.js< / a > < / li >
2013-10-16 13:13:30 +02:00
< / ul >
< / div >
< div class = "table" >
2014-12-11 16:27:11 +01:00
< p > The HTML shown below is the raw HTML table element, before it has been enhanced by DataTables:< / p >
2013-10-16 13:13:30 +02:00
< / div >
< div class = "css" >
< div >
2014-12-11 16:27:11 +01:00
< p > This example uses a little bit of additional CSS beyond what is loaded from the library files (below), in order to correctly display the table. The
additional CSS used is shown below:< / p > < code class = "multiline language-css" > < / code >
2013-10-16 13:13:30 +02:00
< / div >
2014-12-11 16:27:11 +01:00
< p > The following CSS library files are loaded for use in this example to provide the styling of the table:< / p >
2013-10-16 13:13:30 +02:00
< ul >
2014-12-11 16:27:11 +01:00
< li > < a href = "../../media/css/jquery.dataTables.css" > ../../media/css/jquery.dataTables.css< / a > < / li >
2013-10-16 13:13:30 +02:00
< / ul >
< / div >
< div class = "ajax" >
2014-12-11 16:27:11 +01:00
< p > This table loads data by Ajax. The latest data that has been loaded is shown below. This data will update automatically as any additional data is
loaded.< / p >
2013-10-16 13:13:30 +02:00
< / div >
2014-01-17 17:45:14 +01:00
< div class = "php" >
2014-12-11 16:27:11 +01:00
< p > The script used to perform the server-side processing for this table is shown below. Please note that this is just an example script using PHP. Server-side
processing scripts can be written in any language, using < a href = "//datatables.net/manual/server-side" > the protocol described in the DataTables
documentation< / a > .< / p >
2014-01-17 17:45:14 +01:00
< / div >
2013-10-16 13:13:30 +02:00
< / div >
< / section >
< / div >
< section >
< div class = "footer" >
< div class = "gradient" > < / div >
< div class = "liner" >
< h2 > Other examples< / h2 >
< div class = "toc" >
< div class = "toc-group" >
2014-01-17 17:45:14 +01:00
< h3 > < a href = "../basic_init/index.html" > Basic initialisation< / a > < / h3 >
2013-10-16 13:13:30 +02:00
< ul class = "toc" >
< li > < a href = "../basic_init/zero_configuration.html" > Zero configuration< / a > < / li >
< li > < a href = "../basic_init/filter_only.html" > Feature enable / disable< / a > < / li >
2013-11-12 20:18:51 +01:00
< li > < a href = "../basic_init/table_sorting.html" > Default ordering (sorting)< / a > < / li >
< li > < a href = "../basic_init/multi_col_sort.html" > Multi-column ordering< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../basic_init/multiple_tables.html" > Multiple tables< / a > < / li >
< li > < a href = "../basic_init/hidden_columns.html" > Hidden columns< / a > < / li >
2014-12-11 16:27:11 +01:00
< li > < a href = "../basic_init/complex_header.html" > Complex headers (rowspan and colspan)< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../basic_init/dom.html" > DOM positioning< / a > < / li >
< li > < a href = "../basic_init/flexible_width.html" > Flexible table width< / a > < / li >
< li > < a href = "../basic_init/state_save.html" > State saving< / a > < / li >
< li > < a href = "../basic_init/alt_pagination.html" > Alternative pagination< / a > < / li >
< li > < a href = "../basic_init/scroll_y.html" > Scroll - vertical< / a > < / li >
< li > < a href = "../basic_init/scroll_x.html" > Scroll - horizontal< / a > < / li >
< li > < a href = "../basic_init/scroll_xy.html" > Scroll - horizontal and vertical< / a > < / li >
2014-12-11 16:27:11 +01:00
< li > < a href = "../basic_init/scroll_y_theme.html" > Scroll - vertical with jQuery UI ThemeRoller< / a > < / li >
2014-02-10 18:07:22 +01:00
< li > < a href = "../basic_init/comma-decimal.html" > Language - Comma decimal place< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../basic_init/language.html" > Language options< / a > < / li >
< / ul >
< / div >
< div class = "toc-group" >
2014-01-17 17:45:14 +01:00
< h3 > < a href = "../advanced_init/index.html" > Advanced initialisation< / a > < / h3 >
2013-10-16 13:13:30 +02:00
< ul class = "toc" >
2013-10-16 16:33:34 +02:00
< li > < a href = "../advanced_init/events_live.html" > DOM / jQuery events< / a > < / li >
< li > < a href = "../advanced_init/dt_events.html" > DataTables events< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../advanced_init/column_render.html" > Column rendering< / a > < / li >
2013-10-16 16:33:34 +02:00
< li > < a href = "../advanced_init/length_menu.html" > Page length options< / a > < / li >
2014-12-11 16:27:11 +01:00
< li > < a href = "../advanced_init/dom_multiple_elements.html" > Multiple table control elements< / a > < / li >
< li > < a href = "../advanced_init/complex_header.html" > Complex headers (rowspan / colspan)< / a > < / li >
2014-10-08 15:19:14 +02:00
< li > < a href = "../advanced_init/object_dom_read.html" > Read HTML to data objects< / a > < / li >
2015-02-06 17:35:34 +01:00
< li > < a href = "../advanced_init/html5-data-attributes.html" > HTML5 data-* attributes - cell data< / a > < / li >
< li > < a href = "../advanced_init/html5-data-options.html" > HTML5 data-* attributes - table options< / a > < / li >
2013-10-16 16:33:34 +02:00
< li > < a href = "../advanced_init/language_file.html" > Language file< / a > < / li >
< li > < a href = "../advanced_init/defaults.html" > Setting defaults< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../advanced_init/row_callback.html" > Row created callback< / a > < / li >
2013-10-16 16:33:34 +02:00
< li > < a href = "../advanced_init/row_grouping.html" > Row grouping< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../advanced_init/footer_callback.html" > Footer callback< / a > < / li >
2013-10-16 16:33:34 +02:00
< li > < a href = "../advanced_init/dom_toolbar.html" > Custom toolbar elements< / a > < / li >
2014-12-11 16:27:11 +01:00
< li > < a href = "../advanced_init/sort_direction_control.html" > Order direction sequence control< / a > < / li >
2013-10-16 13:13:30 +02:00
< / ul >
< / div >
< div class = "toc-group" >
< h3 > < a href = "../styling/index.html" > Styling< / a > < / h3 >
< ul class = "toc" >
< li > < a href = "../styling/display.html" > Base style< / a > < / li >
< li > < a href = "../styling/no-classes.html" > Base style - no styling classes< / a > < / li >
< li > < a href = "../styling/cell-border.html" > Base style - cell borders< / a > < / li >
2014-06-23 16:34:52 +02:00
< li > < a href = "../styling/compact.html" > Base style - compact< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../styling/hover.html" > Base style - hover< / a > < / li >
2013-11-12 20:18:51 +01:00
< li > < a href = "../styling/order-column.html" > Base style - order-column< / a > < / li >
2014-06-23 16:34:52 +02:00
< li > < a href = "../styling/row-border.html" > Base style - row borders< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../styling/stripe.html" > Base style - stripe< / a > < / li >
< li > < a href = "../styling/bootstrap.html" > Bootstrap< / a > < / li >
< li > < a href = "../styling/foundation.html" > Foundation< / a > < / li >
2014-06-23 16:34:52 +02:00
< li > < a href = "../styling/jqueryUI.html" > jQuery UI ThemeRoller< / a > < / li >
2013-10-16 13:13:30 +02:00
< / ul >
< / div >
< div class = "toc-group" >
2014-01-17 17:45:14 +01:00
< h3 > < a href = "../data_sources/index.html" > Data sources< / a > < / h3 >
2013-10-16 13:13:30 +02:00
< ul class = "toc" >
2014-01-17 17:45:14 +01:00
< li > < a href = "../data_sources/dom.html" > HTML (DOM) sourced data< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../data_sources/ajax.html" > Ajax sourced data< / a > < / li >
< li > < a href = "../data_sources/js_array.html" > Javascript sourced data< / a > < / li >
< li > < a href = "../data_sources/server_side.html" > Server-side processing< / a > < / li >
< / ul >
< / div >
2014-01-17 17:45:14 +01:00
< div class = "toc-group" >
< h3 > < a href = "../api/index.html" > API< / a > < / h3 >
< ul class = "toc" >
< li > < a href = "../api/add_row.html" > Add rows< / a > < / li >
2014-07-18 13:09:54 +02:00
< li > < a href = "../api/multi_filter.html" > Individual column searching (text inputs)< / a > < / li >
2014-12-11 16:27:11 +01:00
< li > < a href = "../api/multi_filter_select.html" > Individual column searching (select inputs)< / a > < / li >
2014-01-17 17:45:14 +01:00
< li > < a href = "../api/highlight.html" > Highlighting rows and columns< / a > < / li >
2014-12-11 16:27:11 +01:00
< li > < a href = "../api/row_details.html" > Child rows (show extra / detailed information)< / a > < / li >
2014-01-17 17:45:14 +01:00
< li > < a href = "../api/select_row.html" > Row selection (multiple rows)< / a > < / li >
2014-12-11 16:27:11 +01:00
< li > < a href = "../api/select_single_row.html" > Row selection and deletion (single row)< / a > < / li >
2014-01-17 17:45:14 +01:00
< li > < a href = "../api/form.html" > Form inputs< / a > < / li >
< li > < a href = "../api/counter_columns.html" > Index column< / a > < / li >
< li > < a href = "../api/show_hide.html" > Show / hide columns dynamically< / a > < / li >
< li > < a href = "../api/api_in_init.html" > Using API in callbacks< / a > < / li >
< li > < a href = "../api/tabs_and_scrolling.html" > Scrolling and jQuery UI tabs< / a > < / li >
2014-07-18 13:09:03 +02:00
< li > < a href = "../api/regex.html" > Search API (regular expressions)< / a > < / li >
2014-01-17 17:45:14 +01:00
< / ul >
< / div >
2013-10-16 13:13:30 +02:00
< div class = "toc-group" >
< h3 > < a href = "../ajax/index.html" > Ajax< / a > < / h3 >
< ul class = "toc" >
< li > < a href = "../ajax/simple.html" > Ajax data source (arrays)< / a > < / li >
< li > < a href = "../ajax/objects.html" > Ajax data source (objects)< / a > < / li >
< li > < a href = "../ajax/deep.html" > Nested object data (objects)< / a > < / li >
< li > < a href = "../ajax/objects_subarrays.html" > Nested object data (arrays)< / a > < / li >
2014-01-14 16:51:06 +01:00
< li > < a href = "../ajax/orthogonal-data.html" > Orthogonal data< / a > < / li >
2013-10-16 13:13:30 +02:00
< li > < a href = "../ajax/null_data_source.html" > Generated content for a column< / a > < / li >
< li > < a href = "../ajax/custom_data_property.html" > Custom data source property< / a > < / li >
< li > < a href = "../ajax/custom_data_flat.html" > Flat array data source< / a > < / li >
< li > < a href = "../ajax/defer_render.html" > Deferred rendering for speed< / a > < / li >
< / ul >
< / div >
< div class = "toc-group" >
2014-01-17 17:45:14 +01:00
< h3 > < a href = "./index.html" > Server-side< / a > < / h3 >
2013-10-16 13:13:30 +02:00
< ul class = "toc active" >
< li > < a href = "./simple.html" > Server-side processing< / a > < / li >
< li > < a href = "./custom_vars.html" > Custom HTTP variables< / a > < / li >
< li > < a href = "./post.html" > POST data< / a > < / li >
< li class = "active" > < a href = "./ids.html" > Automatic addition of row ID attributes< / a > < / li >
< li > < a href = "./object_data.html" > Object data source< / a > < / li >
< li > < a href = "./row_details.html" > Row details< / a > < / li >
< li > < a href = "./select_rows.html" > Row selection< / a > < / li >
< li > < a href = "./jsonp.html" > JSONP data source for remote domains< / a > < / li >
< li > < a href = "./defer_loading.html" > Deferred loading of data< / a > < / li >
< li > < a href = "./pipeline.html" > Pipelining data to reduce Ajax calls for paging< / a > < / li >
< / ul >
< / div >
< div class = "toc-group" >
< h3 > < a href = "../plug-ins/index.html" > Plug-ins< / a > < / h3 >
< ul class = "toc" >
< li > < a href = "../plug-ins/api.html" > API plug-in methods< / a > < / li >
2014-12-11 16:27:11 +01:00
< li > < a href = "../plug-ins/sorting_auto.html" > Ordering plug-ins (with type detection)< / a > < / li >
< li > < a href = "../plug-ins/sorting_manual.html" > Ordering plug-ins (no type detection)< / a > < / li >
2014-02-10 18:06:57 +01:00
< li > < a href = "../plug-ins/range_filtering.html" > Custom filtering - range search< / a > < / li >
2013-11-12 20:18:51 +01:00
< li > < a href = "../plug-ins/dom_sort.html" > Live DOM ordering< / a > < / li >
2013-10-16 13:13:30 +02:00
< / ul >
< / div >
< / div >
< div class = "epilogue" >
2014-12-11 16:27:11 +01:00
< p > Please refer to the < a href = "http://www.datatables.net" > DataTables documentation< / a > for full information about its API properties and methods.< br >
Additionally, there are a wide range of < a href = "http://www.datatables.net/extras" > extras< / a > and < a href = "http://www.datatables.net/plug-ins" > plug-ins< / a >
which extend the capabilities of DataTables.< / p >
2015-01-11 17:26:59 +01:00
< p class = "copyright" > DataTables designed and created by < a href = "http://www.sprymedia.co.uk" > SpryMedia Ltd< / a > © 2007-2015< br >
2013-10-16 13:13:30 +02:00
DataTables is licensed under the < a href = "http://www.datatables.net/mit" > MIT license< / a > .< / p >
< / div >
< / div >
< / div >
< / section >
< / body >
< / html >