Although Editor comes with a number of field types built in, you might find that the built in controls don't do exactly what you would like, or you want to present a completely custom control. For these eventualities Editor's field types are designed to be completely extensible and you can create plug-ins to provide your custom controls, or use some of the ones already available.
This example shows how you might create a binary switch using button
elements, effectively implementing a custom radio
control. This might be useful for styling, as shown in this example.
For more detailed information on how to create plug-ins for Editor, please refer to the Editor documentation.
Priority | Item | Status |
---|
The Javascript shown below is used to initialise the table shown in this example:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 | // Todo field type plug-in code ( function ($, DataTable) { if ( ! DataTable.ext.editorFields ) { DataTable.ext.editorFields = {}; } var Editor = DataTable.Editor; var _fieldTypes = DataTable.ext.editorFields; _fieldTypes.todo = { create: function ( conf ) { var that = this ; conf._enabled = true ; // Create the elements to use for the input conf._input = $( '<div id="' +Editor.safeId( conf.id )+ '">' + '<button type="button" class="inputButton" value="0">To do</button>' + '<button type="button" class="inputButton" value="1">Done</button>' + '</div>' ); // Use the fact that we are called in the Editor instance's scope to call // the API method for setting the value when needed $('button.inputButton ', conf._input).click( function () { if ( conf._enabled ) { that.set( conf.name, $(this).attr(' value ') ); } return false; } ); return conf._input; }, get: function ( conf ) { return $(' button.selected ', conf._input).attr(' value '); }, set: function ( conf, val ) { $(' button.selected ', conf._input).removeClass( ' selected ' ); $(' button.inputButton[value= '+val+' ] ', conf._input).addClass(' selected '); }, enable: function ( conf ) { conf._enabled = true; $(conf._input).removeClass( ' disabled ' ); }, disable: function ( conf ) { conf._enabled = false; $(conf._input).addClass( ' disabled ' ); } }; })(jQuery, jQuery.fn.dataTable); var editor; // use a global for the submit and return data rendering in the examples $(document).ready(function() { editor = new $.fn.dataTable.Editor( { ajax: "../../controllers/todo.php", table: "#example", fields: [ { label: "Item:", name: "item" }, { label: "Status:", name: "done", type: "todo", // Using the custom field type def: 0 }, { label: "Priority:", name: "priority", type: "select", options: [ { label: "1 (highest)", value: "1" }, { label: "2", value: "2" }, { label: "3", value: "3" }, { label: "4", value: "4" }, { label: "5 (lowest)", value: "5" } ] } ] } ); $(' #example').DataTable( { dom: "Bfrtip" , ajax: "../../controllers/todo.php" , columns: [ { data: "priority" , className: "center" }, { data: "item" }, { className: "center" , data: "done" , render: function (data, type, row) { if ( type === 'display ' || type === ' filter' ) { // Filtering and display get the rendered string return data == 0 ? "To do" : "Done" ; } // Otherwise just give the original data return data; } } ], select: true , buttons: [ { extend: "create" , editor: editor }, { extend: "edit" , editor: editor }, { extend: "remove" , editor: editor } ] } ); } ); |
In addition to the above code, the following Javascript library files are loaded for use in this example:
The HTML shown below is the raw HTML table element, before it has been enhanced by DataTables:
<table id="example" class="display" style="width:100%">
<thead>
<tr>
<th>Priority</th>
<th>Item</th>
<th>Status</th>
</tr>
</thead>
</table><table border="0" cellpadding="0" cellspacing="0"><tbody><tr><td class="gutter"><div class="line number1 index0 alt2">1</div><div class="line number2 index1 alt1">2</div><div class="line number3 index2 alt2">3</div><div class="line number4 index3 alt1">4</div><div class="line number5 index4 alt2">5</div><div class="line number6 index5 alt1">6</div><div class="line number7 index6 alt2">7</div><div class="line number8 index7 alt1">8</div><div class="line number9 index8 alt2">9</div><div class="line number10 index9 alt1">10</div><div class="line number11 index10 alt2">11</div><div class="line number12 index11 alt1">12</div><div class="line number13 index12 alt2">13</div><div class="line number14 index13 alt1">14</div><div class="line number15 index14 alt2">15</div><div class="line number16 index15 alt1">16</div><div class="line number17 index16 alt2">17</div><div class="line number18 index17 alt1">18</div><div class="line number19 index18 alt2">19</div><div class="line number20 index19 alt1">20</div><div class="line number21 index20 alt2">21</div><div class="line number22 index21 alt1">22</div><div class="line number23 index22 alt2">23</div><div class="line number24 index23 alt1">24</div><div class="line number25 index24 alt2">25</div><div class="line number26 index25 alt1">26</div><div class="line number27 index26 alt2">27</div><div class="line number28 index27 alt1">28</div><div class="line number29 index28 alt2">29</div><div class="line number30 index29 alt1">30</div><div class="line number31 index30 alt2">31</div><div class="line number32 index31 alt1">32</div><div class="line number33 index32 alt2">33</div><div class="line number34 index33 alt1">34</div><div class="line number35 index34 alt2">35</div><div class="line number36 index35 alt1">36</div><div class="line number37 index36 alt2">37</div><div class="line number38 index37 alt1">38</div><div class="line number39 index38 alt2">39</div><div class="line number40 index39 alt1">40</div><div class="line number41 index40 alt2">41</div><div class="line number42 index41 alt1">42</div><div class="line number43 index42 alt2">43</div><div class="line number44 index43 alt1">44</div><div class="line number45 index44 alt2">45</div><div class="line number46 index45 alt1">46</div><div class="line number47 index46 alt2">47</div><div class="line number48 index47 alt1">48</div><div class="line number49 index48 alt2">49</div><div class="line number50 index49 alt1">50</div><div class="line number51 index50 alt2">51</div><div class="line number52 index51 alt1">52</div><div class="line number53 index52 alt2">53</div><div class="line number54 index53 alt1">54</div><div class="line number55 index54 alt2">55</div><div class="line number56 index55 alt1">56</div><div class="line number57 index56 alt2">57</div><div class="line number58 index57 alt1">58</div><div class="line number59 index58 alt2">59</div><div class="line number60 index59 alt1">60</div><div class="line number61 index60 alt2">61</div><div class="line number62 index61 alt1">62</div><div class="line number63 index62 alt2">63</div><div class="line number64 index63 alt1">64</div><div class="line number65 index64 alt2">65</div><div class="line number66 index65 alt1">66</div><div class="line number67 index66 alt2">67</div><div class="line number68 index67 alt1">68</div><div class="line number69 index68 alt2">69</div><div class="line number70 index69 alt1">70</div><div class="line number71 index70 alt2">71</div><div class="line number72 index71 alt1">72</div><div class="line number73 index72 alt2">73</div><div class="line number74 index73 alt1">74</div><div class="line number75 index74 alt2">75</div><div class="line number76 index75 alt1">76</div><div class="line number77 index76 alt2">77</div><div class="line number78 index77 alt1">78</div><div class="line number79 index78 alt2">79</div><div class="line number80 index79 alt1">80</div><div class="line number81 index80 alt2">81</div><div class="line number82 index81 alt1">82</div><div class="line number83 index82 alt2">83</div><div class="line number84 index83 alt1">84</div><div class="line number85 index84 alt2">85</div><div class="line number86 index85 alt1">86</div><div class="line number87 index86 alt2">87</div><div class="line number88 index87 alt1">88</div><div class="line number89 index88 alt2">89</div><div class="line number90 index89 alt1">90</div><div class="line number91 index90 alt2">91</div><div class="line number92 index91 alt1">92</div><div class="line number93 index92 alt2">93</div><div class="line number94 index93 alt1">94</div><div class="line number95 index94 alt2">95</div><div class="line number96 index95 alt1">96</div><div class="line number97 index96 alt2">97</div><div class="line number98 index97 alt1">98</div><div class="line number99 index98 alt2">99</div><div class="line number100 index99 alt1">100</div><div class="line number101 index100 alt2">101</div><div class="line number102 index101 alt1">102</div><div class="line number103 index102 alt2">103</div><div class="line number104 index103 alt1">104</div><div class="line number105 index104 alt2">105</div><div class="line number106 index105 alt1">106</div><div class="line number107 index106 alt2">107</div><div class="line number108 index107 alt1">108</div><div class="line number109 index108 alt2">109</div><div class="line number110 index109 alt1">110</div><div class="line number111 index110 alt2">111</div><div class="line number112 index111 alt1">112</div><div class="line number113 index112 alt2">113</div><div class="line number114 index113 alt1">114</div><div class="line number115 index114 alt2">115</div></td><td class="code"><div class="container"><div class="line number1 index0 alt2"><code class="js comments">// Todo field type plug-in code</code></div><div class="line number2 index1 alt1"><code class="js plain">(</code><code class="js keyword">function</code> <code class="js plain">($, DataTable) {</code></div><div class="line number3 index2 alt2"> </div><div class="line number4 index3 alt1"><code class="js keyword">if</code> <code class="js plain">( ! DataTable.ext.editorFields ) {</code></div><div class="line number5 index4 alt2"><code class="js spaces"> </code><code class="js plain">DataTable.ext.editorFields = {};</code></div><div class="line number6 index5 alt1"><code class="js plain">}</code></div><div class="line number7 index6 alt2"> </div><div class="line number8 index7 alt1"><code class="js keyword">var</code> <code class="js plain">Editor = DataTable.Editor;</code></div><div class="line number9 index8 alt2"><code class="js keyword">var</code> <code class="js plain">_fieldTypes = DataTable.ext.editorFields;</code></div><div class="line number10 index9 alt1"> </div><div class="line number11 index10 alt2"><code class="js plain">_fieldTypes.todo = {</code></div><div class="line number12 index11 alt1"><code class="js spaces"> </code><code class="js plain">create: </code><code class="js keyword">function</code> <code class="js plain">( conf ) {</code></div><div class="line number13 index12 alt2"><code class="js spaces"> </code><code class="js keyword">var</code> <code class="js plain">that = </code><code class="js keyword">this</code><code class="js plain">;</code></div><div class="line number14 index13 alt1"> </div><div class="line number15 index14 alt2"><code class="js spaces"> </code><code class="js plain">conf._enabled = </code><code class="js keyword">true</code><code class="js plain">;</code></div><div class="line number16 index15 alt1"> </div><div class="line number17 index16 alt2"><code class="js spaces"> </code><code class="js comments">// Create the elements to use for the input</code></div><div class="line number18 index17 alt1"><code class="js spaces"> </code><code class="js plain">conf._input = $(</code></div><div class="line number19 index18 alt2"><code class="js spaces"> </code><code class="js string">'<div id="'</code><code class="js plain">+Editor.safeId( conf.id )+</code><code class="js string">'">'</code><code class="js plain">+</code></div><div class="line number20 index19 alt1"><code class="js spaces"> </code><code class="js string">'<button type="button" class="inputButton" value="0">To do</button>'</code><code class="js plain">+</code></div><div class="line number21 index20 alt2"><code class="js spaces"> </code><code class="js string">'<button type="button" class="inputButton" value="1">Done</button>'</code><code class="js plain">+</code></div><div class="line number22 index21 alt1"><code class="js spaces"> </code><code class="js string">'</div>'</code><code class="js plain">);</code></div><div class="line number23 index22 alt2"> </div><div class="line number24 index23 alt1"><code class="js spaces"> </code><code class="js comments">// Use the fact that we are called in the Editor instance's scope to call</code></div><div class="line number25 index24 alt2"><code class="js spaces"> </code><code class="js comments">// the API method for setting the value when needed</code></div><div class="line number26 index25 alt1"><code class="js spaces"> </code><code class="js plain">$('button.inputButton</code><code class="js string">', conf._input).click( function () {</code></div><div class="line number27 index26 alt2"><code class="js spaces"> </code><code class="js string">if ( conf._enabled ) {</code></div><div class="line number28 index27 alt1"><code class="js spaces"> </code><code class="js string">that.set( conf.name, $(this).attr('</code><code class="js plain">value</code><code class="js string">') );</code></div><div class="line number29 index28 alt2"><code class="js spaces"> </code><code class="js string">}</code></div><div class="line number30 index29 alt1"> </div><div class="line number31 index30 alt2"><code class="js spaces"> </code><code class="js string">return false;</code></div><div class="line number32 index31 alt1"><code class="js spaces"> </code><code class="js string">} );</code></div><div class="line number33 index32 alt2"> </div><div class="line number34 index33 alt1"><code class="js spaces"> </code><code class="js string">return conf._input;</code></div><div class="line number35 index34 alt2"><code class="js spaces"> </code><code class="js string">},</code></div><div class="line number36 index35 alt1"> </div><div class="line number37 index36 alt2"><code class="js spaces"> </code><code class="js string">get: function ( conf ) {</code></div><div class="line number38 index37 alt1"><code class="js spaces"> </code><code class="js string">return $('</code><code class="js plain">button.selected</code><code class="js string">', conf._input).attr('</code><code class="js plain">value</code><code class="js string">');</code></div><div class="line number39 index38 alt2"><code class="js spaces"> </code><code class="js string">},</code></div><div class="line number40 index39 alt1"> </div><div class="line number41 index40 alt2"><code class="js spaces"> </code><code class="js string">set: function ( conf, val ) {</code></div><div class="line number42 index41 alt1"><code class="js spaces"> </code><code class="js string">$('</code><code class="js plain">button.selected</code><code class="js string">', conf._input).removeClass( '</code><code class="js plain">selected</code><code class="js string">' );</code></div><div class="line number43 index42 alt2"><code class="js spaces"> </code><code class="js string">$('</code><code class="js plain">button.inputButton[value=</code><code class="js string">'+val+'</code><code class="js plain">]</code><code class="js string">', conf._input).addClass('</code><code class="js plain">selected</code><code class="js string">');</code></div><div class="line number44 index43 alt1"><code class="js spaces"> </code><code class="js string">},</code></div><div class="line number45 index44 alt2"> </div><div class="line number46 index45 alt1"><code class="js spaces"> </code><code class="js string">enable: function ( conf ) {</code></div><div class="line number47 index46 alt2"><code class="js spaces"> </code><code class="js string">conf._enabled = true;</code></div><div class="line number48 index47 alt1"><code class="js spaces"> </code><code class="js string">$(conf._input).removeClass( '</code><code class="js plain">disabled</code><code class="js string">' );</code></div><div class="line number49 index48 alt2"><code class="js spaces"> </code><code class="js string">},</code></div><div class="line number50 index49 alt1"> </div><div class="line number51 index50 alt2"><code class="js spaces"> </code><code class="js string">disable: function ( conf ) {</code></div><div class="line number52 index51 alt1"><code class="js spaces"> </code><code class="js string">conf._enabled = false;</code></div><div class="line number53 index52 alt2"><code class="js spaces"> </code><code class="js string">$(conf._input).addClass( '</code><code class="js plain">disabled</code><code class="js string">' );</code></div><div class="line number54 index53 alt1"><code class="js spaces"> </code><code class="js string">}</code></div><div class="line number55 index54 alt2"><code class="js string">};</code></div><div class="line number56 index55 alt1"> </div><div class="line number57 index56 alt2"><code class="js string">})(jQuery, jQuery.fn.dataTable);</code></div><div class="line number58 index57 alt1"> </div><div class="line number59 index58 alt2"> </div><div class="line number60 index59 alt1"><code class="js string">var editor; // use a global for the submit and return data rendering in the examples</code></div><div class="line number61 index60 alt2"> </div><div class="line number62 index61 alt1"><code class="js string">$(document).ready(function() {</code></div><div class="line number63 index62 alt2"><code class="js spaces"> </code><code class="js string">editor = new $.fn.dataTable.Editor( {</code></div><div class="line number64 index63 alt1"><code class="js spaces"> </code><code class="js string">ajax: "../../controllers/todo.php",</code></div><div class="line number65 index64 alt2"><code class="js spaces"> </code><code class="js string">table: "#example",</code></div><div class="line number66 index65 alt1"><code class="js spaces"> </code><code class="js string">fields: [ {</code></div><div class="line number67 index66 alt2"><code class="js spaces"> </code><code class="js string">label: "Item:",</code></div><div class="line number68 index67 alt1"><code class="js spaces"> </code><code class="js string">name: "item"</code></div><div class="line number69 index68 alt2"><code class="js spaces"> </code><code class="js string">}, {</code></div><div class="line number70 index69 alt1"><code class="js spaces"> </code><code class="js string">label: "Status:",</code></div><div class="line number71 index70 alt2"><code class="js spaces"> </code><code class="js string">name: "done",</code></div><div class="line number72 index71 alt1"><code class="js spaces"> </code><code class="js string">type: "todo", // Using the custom field type</code></div><div class="line number73 index72 alt2"><code class="js spaces"> </code><code class="js string">def: 0</code></div><div class="line number74 index73 alt1"><code class="js spaces"> </code><code class="js string">}, {</code></div><div class="line number75 index74 alt2"><code class="js spaces"> </code><code class="js string">label: "Priority:",</code></div><div class="line number76 index75 alt1"><code class="js spaces"> </code><code class="js string">name: "priority",</code></div><div class="line number77 index76 alt2"><code class="js spaces"> </code><code class="js string">type: "select",</code></div><div class="line number78 index77 alt1"><code class="js spaces"> </code><code class="js string">options: [</code></div><div class="line number79 index78 alt2"><code class="js spaces"> </code><code class="js string">{ label: "1 (highest)", value: "1" },</code></div><div class="line number80 index79 alt1"><code class="js spaces"> </code><code class="js string">{ label: "2", value: "2" },</code></div><div class="line number81 index80 alt2"><code class="js spaces"> </code><code class="js string">{ label: "3", value: "3" },</code></div><div class="line number82 index81 alt1"><code class="js spaces"> </code><code class="js string">{ label: "4", value: "4" },</code></div><div class="line number83 index82 alt2"><code class="js spaces"> </code><code class="js string">{ label: "5 (lowest)", value: "5" }</code></div><div class="line number84 index83 alt1"><code class="js spaces"> </code><code class="js string">]</code></div><div class="line number85 index84 alt2"><code class="js spaces"> </code><code class="js string">}</code></div><div class="line number86 index85 alt1"><code class="js spaces"> </code><code class="js string">]</code></div><div class="line number87 index86 alt2"><code class="js spaces"> </code><code class="js string">} );</code></div><div class="line number88 index87 alt1"> </div><div class="line number89 index88 alt2"><code class="js spaces"> </code><code class="js string">$('</code><code class="js preprocessor">#example').DataTable( {</code></div><div class="line number90 index89 alt1"><code class="js spaces"> </code><code class="js plain">dom: </code><code class="js string">"Bfrtip"</code><code class="js plain">,</code></div><div class="line number91 index90 alt2"><code class="js spaces"> </code><code class="js plain">ajax: </code><code class="js string">"../../controllers/todo.php"</code><code class="js plain">,</code></div><div class="line number92 index91 alt1"><code class="js spaces"> </code><code class="js plain">columns: [</code></div><div class="line number93 index92 alt2"><code class="js spaces"> </code><code class="js plain">{ data: </code><code class="js string">"priority"</code><code class="js plain">, className: </code><code class="js string">"center"</code> <code class="js plain">},</code></div><div class="line number94 index93 alt1"><code class="js spaces"> </code><code class="js plain">{ data: </code><code class="js string">"item"</code> <code class="js plain">},</code></div><div class="line number95 index94 alt2"><code class="js spaces"> </code><code class="js plain">{ </code></div><div class="line number96 index95 alt1"><code class="js spaces"> </code><code class="js plain">className: </code><code class="js string">"center"</code><code class="js plain">,</code></div><div class="line number97 index96 alt2"><code class="js spaces"> </code><code class="js plain">data: </code><code class="js string">"done"</code><code class="js plain">,</code></div><div class="line number98 index97 alt1"><code class="js spaces"> </code><code class="js plain">render: </code><code class="js keyword">function</code> <code class="js plain">(data, type, row) {</code></div><div class="line number99 index98 alt2"><code class="js spaces"> </code><code class="js keyword">if</code> <code class="js plain">( type === 'display</code><code class="js string">' || type === '</code><code class="js plain">filter' ) {</code></div><div class="line number100 index99 alt1"><code class="js spaces"> </code><code class="js comments">// Filtering and display get the rendered string</code></div><div class="line number101 index100 alt2"><code class="js spaces"> </code><code class="js keyword">return</code> <code class="js plain">data == 0 ? </code><code class="js string">"To do"</code> <code class="js plain">: </code><code class="js string">"Done"</code><code class="js plain">;</code></div><div class="line number102 index101 alt1"><code class="js spaces"> </code><code class="js plain">}</code></div><div class="line number103 index102 alt2"><code class="js spaces"> </code><code class="js comments">// Otherwise just give the original data</code></div><div class="line number104 index103 alt1"><code class="js spaces"> </code><code class="js keyword">return</code> <code class="js plain">data;</code></div><div class="line number105 index104 alt2"><code class="js spaces"> </code><code class="js plain">}</code></div><div class="line number106 index105 alt1"><code class="js spaces"> </code><code class="js plain">}</code></div><div class="line number107 index106 alt2"><code class="js spaces"> </code><code class="js plain">],</code></div><div class="line number108 index107 alt1"><code class="js spaces"> </code><code class="js plain">select: </code><code class="js keyword">true</code><code class="js plain">,</code></div><div class="line number109 index108 alt2"><code class="js spaces"> </code><code class="js plain">buttons: [</code></div><div class="line number110 index109 alt1"><code class="js spaces"> </code><code class="js plain">{ extend: </code><code class="js string">"create"</code><code class="js plain">, editor: editor },</code></div><div class="line number111 index110 alt2"><code class="js spaces"> </code><code class="js plain">{ extend: </code><code class="js string">"edit"</code><code class="js plain">, editor: editor },</code></div><div class="line number112 index111 alt1"><code class="js spaces"> </code><code class="js plain">{ extend: </code><code class="js string">"remove"</code><code class="js plain">, editor: editor }</code></div><div class="line number113 index112 alt2"><code class="js spaces"> </code><code class="js plain">]</code></div><div class="line number114 index113 alt1"><code class="js spaces"> </code><code class="js plain">} );</code></div><div class="line number115 index114 alt2"><code class="js plain">} );</code></div></div></td></tr></tbody></table><table border="0" cellpadding="0" cellspacing="0"><tbody><tr><td class="gutter"><div class="line number1 index0 alt2">1</div><div class="line number2 index1 alt1">2</div><div class="line number3 index2 alt2">3</div><div class="line number4 index3 alt1">4</div><div class="line number5 index4 alt2">5</div><div class="line number6 index5 alt1">6</div><div class="line number7 index6 alt2">7</div><div class="line number8 index7 alt1">8</div><div class="line number9 index8 alt2">9</div><div class="line number10 index9 alt1">10</div><div class="line number11 index10 alt2">11</div><div class="line number12 index11 alt1">12</div><div class="line number13 index12 alt2">13</div><div class="line number14 index13 alt1">14</div><div class="line number15 index14 alt2">15</div><div class="line number16 index15 alt1">16</div><div class="line number17 index16 alt2">17</div><div class="line number18 index17 alt1">18</div><div class="line number19 index18 alt2">19</div><div class="line number20 index19 alt1">20</div><div class="line number21 index20 alt2">21</div><div class="line number22 index21 alt1">22</div><div class="line number23 index22 alt2">23</div><div class="line number24 index23 alt1">24</div><div class="line number25 index24 alt2">25</div><div class="line number26 index25 alt1">26</div><div class="line number27 index26 alt2">27</div><div class="line number28 index27 alt1">28</div><div class="line number29 index28 alt2">29</div><div class="line number30 index29 alt1">30</div><div class="line number31 index30 alt2">31</div><div class="line number32 index31 alt1">32</div><div class="line number33 index32 alt2">33</div><div class="line number34 index33 alt1">34</div></td><td class="code"><div class="container"><div class="line number1 index0 alt2"><code class="css plain">button.inputButton {</code></div><div class="line number2 index1 alt1"><code class="css spaces"> </code><code class="css keyword">float</code><code class="css plain">: </code><code class="css value">left</code><code class="css plain">;</code></div><div class="line number3 index2 alt2"><code class="css spaces"> </code><code class="css keyword">text-align</code><code class="css plain">: </code><code class="css value">center</code><code class="css plain">;</code></div><div class="line number4 index3 alt1"><code class="css spaces"> </code><code class="css keyword">display</code><code class="css plain">: </code><code class="css value">block</code><code class="css plain">;</code></div><div class="line number5 index4 alt2"><code class="css spaces"> </code><code class="css keyword">cursor</code><code class="css plain">: </code><code class="css value">pointer</code><code class="css plain">;</code></div><div class="line number6 index5 alt1"><code class="css spaces"> </code><code class="css keyword">margin</code><code class="css plain">: </code><code class="css value">0</code> <code class="css value">20px</code> <code class="css value">10px</code> <code class="css value">0</code><code class="css plain">;</code></div><div class="line number7 index6 alt2"><code class="css spaces"> </code><code class="css keyword">padding</code><code class="css plain">: </code><code class="css value">6px</code> <code class="css value">0</code><code class="css plain">;</code></div><div class="line number8 index7 alt1"><code class="css spaces"> </code><code class="css keyword">background</code><code class="css plain">: </code><code class="css value">#F8F8F8</code><code class="css plain">;</code></div><div class="line number9 index8 alt2"><code class="css spaces"> </code><code class="css keyword">background</code><code class="css plain">: -webkit-gradient(linear, </code><code class="css value">center</code> <code class="css value">bottom</code><code class="css plain">, </code><code class="css value">center</code> <code class="css value">top</code><code class="css plain">, from(</code><code class="css value">#CCC</code><code class="css plain">), to(</code><code class="css value">white</code><code class="css plain">));</code></div><div class="line number10 index9 alt1"><code class="css spaces"> </code><code class="css keyword">background</code><code class="css plain">: -moz-linear-gradient(</code><code class="css value">top</code><code class="css plain">, </code><code class="css value">white</code><code class="css plain">, </code><code class="css value">#CCC</code><code class="css plain">);</code></div><div class="line number11 index10 alt2"><code class="css spaces"> </code><code class="css keyword">background</code><code class="css plain">: linear-gradient(to </code><code class="css value">bottom</code><code class="css plain">, </code><code class="css value">white</code><code class="css plain">, </code><code class="css value">#CCC</code><code class="css plain">);</code></div><div class="line number12 index11 alt1"><code class="css spaces"> </code><code class="css keyword">text-shadow</code><code class="css plain">: </code><code class="css value">0</code> <code class="css value">1px</code> <code class="css value">0</code> <code class="css value">white</code><code class="css plain">;</code></div><div class="line number13 index12 alt2"><code class="css spaces"> </code><code class="css keyword">border</code><code class="css plain">: </code><code class="css value">1px</code> <code class="css value">solid</code> <code class="css value">#999</code><code class="css plain">;</code></div><div class="line number14 index13 alt1"><code class="css spaces"> </code><code class="css plain">border-radius: </code><code class="css value">3px</code><code class="css plain">;</code></div><div class="line number15 index14 alt2"><code class="css spaces"> </code><code class="css plain">-moz-border-radius: </code><code class="css value">3px</code><code class="css plain">;</code></div><div class="line number16 index15 alt1"><code class="css spaces"> </code><code class="css plain">-webkit-border-radius: </code><code class="css value">3px</code><code class="css plain">;</code></div><div class="line number17 index16 alt2"><code class="css spaces"> </code><code class="css plain">box-shadow: </code><code class="css value">0px</code> <code class="css value">0px</code> <code class="css value">2px</code> <code class="css value">#999</code><code class="css plain">;</code></div><div class="line number18 index17 alt1"><code class="css spaces"> </code><code class="css plain">-moz-box-shadow: </code><code class="css value">0px</code> <code class="css value">0px</code> <code class="css value">2px</code> <code class="css value">#999</code><code class="css plain">;</code></div><div class="line number19 index18 alt2"><code class="css spaces"> </code><code class="css plain">-webkit-box-shadow: </code><code class="css value">0px</code> <code class="css value">0px</code> <code class="css value">2px</code> <code class="css value">#999</code><code class="css plain">;</code></div><div class="line number20 index19 alt1"><code class="css spaces"> </code><code class="css keyword">width</code><code class="css plain">: </code><code class="css value">80px</code><code class="css plain">;</code></div><div class="line number21 index20 alt2"><code class="css spaces"> </code><code class="css plain">}</code></div><div class="line number22 index21 alt1"> </div><div class="line number23 index22 alt2"><code class="css spaces"> </code><code class="css plain">button.inputButton.selected {</code></div><div class="line number24 index23 alt1"><code class="css spaces"> </code><code class="css keyword">font-weight</code><code class="css plain">: </code><code class="css value">normal</code><code class="css plain">;</code></div><div class="line number25 index24 alt2"><code class="css spaces"> </code><code class="css keyword">background</code><code class="css plain">: </code><code class="css value">#02475A</code><code class="css plain">;</code></div><div class="line number26 index25 alt1"><code class="css spaces"> </code><code class="css keyword">background</code><code class="css plain">: -webkit-gradient(linear, </code><code class="css value">center</code> <code class="css value">bottom</code><code class="css plain">, </code><code class="css value">center</code> <code class="css value">top</code><code class="css plain">, from(</code><code class="css value">#777</code><code class="css plain">), to(</code><code class="css value">#333</code><code class="css plain">));</code></div><div class="line number27 index26 alt2"><code class="css spaces"> </code><code class="css keyword">background</code><code class="css plain">: -moz-linear-gradient(</code><code class="css value">top</code><code class="css plain">, </code><code class="css value">#333</code><code class="css plain">, </code><code class="css value">#777</code><code class="css plain">);</code></div><div class="line number28 index27 alt1"><code class="css spaces"> </code><code class="css keyword">background</code><code class="css plain">: linear-gradient(to </code><code class="css value">bottom</code><code class="css plain">, </code><code class="css value">#333</code><code class="css plain">, </code><code class="css value">#777</code><code class="css plain">);</code></div><div class="line number29 index28 alt2"><code class="css spaces"> </code><code class="css plain">box-shadow: </code><code class="css value">inset</code> <code class="css value">0px</code> <code class="css value">0px</code> <code class="css value">2px</code> <code class="css value">#222</code><code class="css plain">;</code></div><div class="line number30 index29 alt1"><code class="css spaces"> </code><code class="css plain">-moz-box-shadow: </code><code class="css value">inset</code> <code class="css value">0px</code> <code class="css value">0px</code> <code class="css value">2px</code> <code class="css value">#222</code><code class="css plain">;</code></div><div class="line number31 index30 alt2"><code class="css spaces"> </code><code class="css plain">-webkit-box-shadow: </code><code class="css value">inset</code> <code class="css value">0px</code> <code class="css value">0px</code> <code class="css value">2px</code> <code class="css value">#222</code><code class="css plain">;</code></div><div class="line number32 index31 alt1"><code class="css spaces"> </code><code class="css keyword">color</code><code class="css plain">: </code><code class="css value">white</code><code class="css plain">;</code></div><div class="line number33 index32 alt2"><code class="css spaces"> </code><code class="css keyword">text-shadow</code><code class="css plain">: </code><code class="css value">none</code><code class="css plain">;</code></div><div class="line number34 index33 alt1"><code class="css spaces"> </code><code class="css plain">}</code></div></div></td></tr></tbody></table>
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:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 | button.inputButton { float : left ; text-align : center ; display : block ; cursor : pointer ; margin : 0 20px 10px 0 ; padding : 6px 0 ; background : #F8F8F8 ; background : -webkit-gradient(linear, center bottom , center top , from( #CCC ), to( white )); background : -moz-linear-gradient( top , white , #CCC ); background : linear-gradient(to bottom , white , #CCC ); text-shadow : 0 1px 0 white ; border : 1px solid #999 ; border-radius: 3px ; -moz-border-radius: 3px ; -webkit-border-radius: 3px ; box-shadow: 0px 0px 2px #999 ; -moz-box-shadow: 0px 0px 2px #999 ; -webkit-box-shadow: 0px 0px 2px #999 ; width : 80px ; } button.inputButton.selected { font-weight : normal ; background : #02475A ; background : -webkit-gradient(linear, center bottom , center top , from( #777 ), to( #333 )); background : -moz-linear-gradient( top , #333 , #777 ); background : linear-gradient(to bottom , #333 , #777 ); box-shadow: inset 0px 0px 2px #222 ; -moz-box-shadow: inset 0px 0px 2px #222 ; -webkit-box-shadow: inset 0px 0px 2px #222 ; color : white ; text-shadow : none ; } |
The following CSS library files are loaded for use in this example to provide the styling of the table:
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 the protocol described in the DataTables documentation.
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.
Editor submits and retrieves information by Ajax requests. The two blocks below show the data that Editor submits and receives, to and from the server. This is updated live as you interact with Editor so you can see what is submitted.
The following shows the data that has been submitted to the server when a request is made to add, edit or delete data from the table.
// No data yet submitted
The following shows the data that has been returned by the server in response to the data submitted on the left and is then acted upon.
// No data yet received
Please refer to the DataTables documentation for full information about its API properties and methods.
Additionally, there are a wide range of extensions and plug-ins which extend the capabilities of DataTables.
DataTables designed and created by SpryMedia Ltd © 2007-2018
DataTables is licensed under the MIT license.