step-callback.html 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <link rel="shortcut icon" type="image/ico" href="http://www.datatables.net/favicon.ico">
  6. <meta name="viewport" content="initial-scale=1.0, maximum-scale=2.0">
  7. <title>AutoFill example - Step callback</title>
  8. <link rel="stylesheet" type="text/css" href="../../../media/css/jquery.dataTables.css">
  9. <link rel="stylesheet" type="text/css" href="../css/dataTables.autoFill.css">
  10. <link rel="stylesheet" type="text/css" href="../../../examples/resources/syntax/shCore.css">
  11. <link rel="stylesheet" type="text/css" href="../../../examples/resources/demo.css">
  12. <style type="text/css" class="init">
  13. </style>
  14. <script type="text/javascript" language="javascript" src="../../../media/js/jquery.js"></script>
  15. <script type="text/javascript" language="javascript" src="../../../media/js/jquery.dataTables.js"></script>
  16. <script type="text/javascript" language="javascript" src="../js/dataTables.autoFill.js"></script>
  17. <script type="text/javascript" language="javascript" src="../../../examples/resources/syntax/shCore.js"></script>
  18. <script type="text/javascript" language="javascript" src="../../../examples/resources/demo.js"></script>
  19. <script type="text/javascript" language="javascript" class="init">
  20. $(document).ready(function() {
  21. var table = $('#example').dataTable();
  22. new $.fn.dataTable.AutoFill( table, {
  23. columnDefs: [ {
  24. targets: -1,
  25. step: function ( cell, read, last, i, x, y ) {
  26. var val = parseInt( (last || read).replace(/[$,]/g, ''), 10 );
  27. val += (x<0 || y<0 ? -100 : 100); // - if going back up, + if going down
  28. // Format for the currency column
  29. return '$'+val.toString().replace( /\B(?=(\d{3})+(?!\d))/g, ',' );
  30. }
  31. } ]
  32. } );
  33. } );
  34. </script>
  35. </head>
  36. <body class="dt-example">
  37. <div class="container">
  38. <section>
  39. <h1>AutoFill example <span>Step callback</span></h1>
  40. <div class="info">
  41. <p>By default, AutoFill will increment cells that contain numbers by a single digit for each cell that
  42. is iterated over (try the <em>Age</em> column below for example). This behaviour can be disabled
  43. completely using the <code>increment</code> column option, but it can also be modified to suit your
  44. requirements through use of the <code>step</code> column callback function.</p>
  45. <p>The <code>step</code> callback is executed for each cell in the auto-fill set and gives complete
  46. control over how data is incremented. The example below shows the step function being used on the
  47. <em>Salary</em> column to increment by 100, rather than 1 for each cell.</p>
  48. <p>For a complete description of the <code>step</code> callback, please refer to the <a href=
  49. "//datatables.net/extras/autofill/options">AutoFill documentation</a>.</p>
  50. </div>
  51. <table id="example" class="display" cellspacing="0" width="100%">
  52. <thead>
  53. <tr>
  54. <th>Name</th>
  55. <th>Position</th>
  56. <th>Office</th>
  57. <th>Age</th>
  58. <th>Start date</th>
  59. <th>Salary</th>
  60. </tr>
  61. </thead>
  62. <tfoot>
  63. <tr>
  64. <th>Name</th>
  65. <th>Position</th>
  66. <th>Office</th>
  67. <th>Age</th>
  68. <th>Start date</th>
  69. <th>Salary</th>
  70. </tr>
  71. </tfoot>
  72. <tbody>
  73. <tr>
  74. <td>Tiger Nixon</td>
  75. <td>System Architect</td>
  76. <td>Edinburgh</td>
  77. <td>61</td>
  78. <td>2011/04/25</td>
  79. <td>$320,800</td>
  80. </tr>
  81. <tr>
  82. <td>Garrett Winters</td>
  83. <td>Accountant</td>
  84. <td>Tokyo</td>
  85. <td>63</td>
  86. <td>2011/07/25</td>
  87. <td>$170,750</td>
  88. </tr>
  89. <tr>
  90. <td>Ashton Cox</td>
  91. <td>Junior Technical Author</td>
  92. <td>San Francisco</td>
  93. <td>66</td>
  94. <td>2009/01/12</td>
  95. <td>$86,000</td>
  96. </tr>
  97. <tr>
  98. <td>Cedric Kelly</td>
  99. <td>Senior Javascript Developer</td>
  100. <td>Edinburgh</td>
  101. <td>22</td>
  102. <td>2012/03/29</td>
  103. <td>$433,060</td>
  104. </tr>
  105. <tr>
  106. <td>Airi Satou</td>
  107. <td>Accountant</td>
  108. <td>Tokyo</td>
  109. <td>33</td>
  110. <td>2008/11/28</td>
  111. <td>$162,700</td>
  112. </tr>
  113. <tr>
  114. <td>Brielle Williamson</td>
  115. <td>Integration Specialist</td>
  116. <td>New York</td>
  117. <td>61</td>
  118. <td>2012/12/02</td>
  119. <td>$372,000</td>
  120. </tr>
  121. <tr>
  122. <td>Herrod Chandler</td>
  123. <td>Sales Assistant</td>
  124. <td>San Francisco</td>
  125. <td>59</td>
  126. <td>2012/08/06</td>
  127. <td>$137,500</td>
  128. </tr>
  129. <tr>
  130. <td>Rhona Davidson</td>
  131. <td>Integration Specialist</td>
  132. <td>Tokyo</td>
  133. <td>55</td>
  134. <td>2010/10/14</td>
  135. <td>$327,900</td>
  136. </tr>
  137. <tr>
  138. <td>Colleen Hurst</td>
  139. <td>Javascript Developer</td>
  140. <td>San Francisco</td>
  141. <td>39</td>
  142. <td>2009/09/15</td>
  143. <td>$205,500</td>
  144. </tr>
  145. <tr>
  146. <td>Sonya Frost</td>
  147. <td>Software Engineer</td>
  148. <td>Edinburgh</td>
  149. <td>23</td>
  150. <td>2008/12/13</td>
  151. <td>$103,600</td>
  152. </tr>
  153. <tr>
  154. <td>Jena Gaines</td>
  155. <td>Office Manager</td>
  156. <td>London</td>
  157. <td>30</td>
  158. <td>2008/12/19</td>
  159. <td>$90,560</td>
  160. </tr>
  161. <tr>
  162. <td>Quinn Flynn</td>
  163. <td>Support Lead</td>
  164. <td>Edinburgh</td>
  165. <td>22</td>
  166. <td>2013/03/03</td>
  167. <td>$342,000</td>
  168. </tr>
  169. <tr>
  170. <td>Charde Marshall</td>
  171. <td>Regional Director</td>
  172. <td>San Francisco</td>
  173. <td>36</td>
  174. <td>2008/10/16</td>
  175. <td>$470,600</td>
  176. </tr>
  177. <tr>
  178. <td>Haley Kennedy</td>
  179. <td>Senior Marketing Designer</td>
  180. <td>London</td>
  181. <td>43</td>
  182. <td>2012/12/18</td>
  183. <td>$313,500</td>
  184. </tr>
  185. <tr>
  186. <td>Tatyana Fitzpatrick</td>
  187. <td>Regional Director</td>
  188. <td>London</td>
  189. <td>19</td>
  190. <td>2010/03/17</td>
  191. <td>$385,750</td>
  192. </tr>
  193. <tr>
  194. <td>Michael Silva</td>
  195. <td>Marketing Designer</td>
  196. <td>London</td>
  197. <td>66</td>
  198. <td>2012/11/27</td>
  199. <td>$198,500</td>
  200. </tr>
  201. <tr>
  202. <td>Paul Byrd</td>
  203. <td>Chief Financial Officer (CFO)</td>
  204. <td>New York</td>
  205. <td>64</td>
  206. <td>2010/06/09</td>
  207. <td>$725,000</td>
  208. </tr>
  209. <tr>
  210. <td>Gloria Little</td>
  211. <td>Systems Administrator</td>
  212. <td>New York</td>
  213. <td>59</td>
  214. <td>2009/04/10</td>
  215. <td>$237,500</td>
  216. </tr>
  217. <tr>
  218. <td>Bradley Greer</td>
  219. <td>Software Engineer</td>
  220. <td>London</td>
  221. <td>41</td>
  222. <td>2012/10/13</td>
  223. <td>$132,000</td>
  224. </tr>
  225. <tr>
  226. <td>Dai Rios</td>
  227. <td>Personnel Lead</td>
  228. <td>Edinburgh</td>
  229. <td>35</td>
  230. <td>2012/09/26</td>
  231. <td>$217,500</td>
  232. </tr>
  233. <tr>
  234. <td>Jenette Caldwell</td>
  235. <td>Development Lead</td>
  236. <td>New York</td>
  237. <td>30</td>
  238. <td>2011/09/03</td>
  239. <td>$345,000</td>
  240. </tr>
  241. <tr>
  242. <td>Yuri Berry</td>
  243. <td>Chief Marketing Officer (CMO)</td>
  244. <td>New York</td>
  245. <td>40</td>
  246. <td>2009/06/25</td>
  247. <td>$675,000</td>
  248. </tr>
  249. <tr>
  250. <td>Caesar Vance</td>
  251. <td>Pre-Sales Support</td>
  252. <td>New York</td>
  253. <td>21</td>
  254. <td>2011/12/12</td>
  255. <td>$106,450</td>
  256. </tr>
  257. <tr>
  258. <td>Doris Wilder</td>
  259. <td>Sales Assistant</td>
  260. <td>Sidney</td>
  261. <td>23</td>
  262. <td>2010/09/20</td>
  263. <td>$85,600</td>
  264. </tr>
  265. <tr>
  266. <td>Angelica Ramos</td>
  267. <td>Chief Executive Officer (CEO)</td>
  268. <td>London</td>
  269. <td>47</td>
  270. <td>2009/10/09</td>
  271. <td>$1,200,000</td>
  272. </tr>
  273. <tr>
  274. <td>Gavin Joyce</td>
  275. <td>Developer</td>
  276. <td>Edinburgh</td>
  277. <td>42</td>
  278. <td>2010/12/22</td>
  279. <td>$92,575</td>
  280. </tr>
  281. <tr>
  282. <td>Jennifer Chang</td>
  283. <td>Regional Director</td>
  284. <td>Singapore</td>
  285. <td>28</td>
  286. <td>2010/11/14</td>
  287. <td>$357,650</td>
  288. </tr>
  289. <tr>
  290. <td>Brenden Wagner</td>
  291. <td>Software Engineer</td>
  292. <td>San Francisco</td>
  293. <td>28</td>
  294. <td>2011/06/07</td>
  295. <td>$206,850</td>
  296. </tr>
  297. <tr>
  298. <td>Fiona Green</td>
  299. <td>Chief Operating Officer (COO)</td>
  300. <td>San Francisco</td>
  301. <td>48</td>
  302. <td>2010/03/11</td>
  303. <td>$850,000</td>
  304. </tr>
  305. <tr>
  306. <td>Shou Itou</td>
  307. <td>Regional Marketing</td>
  308. <td>Tokyo</td>
  309. <td>20</td>
  310. <td>2011/08/14</td>
  311. <td>$163,000</td>
  312. </tr>
  313. <tr>
  314. <td>Michelle House</td>
  315. <td>Integration Specialist</td>
  316. <td>Sidney</td>
  317. <td>37</td>
  318. <td>2011/06/02</td>
  319. <td>$95,400</td>
  320. </tr>
  321. <tr>
  322. <td>Suki Burks</td>
  323. <td>Developer</td>
  324. <td>London</td>
  325. <td>53</td>
  326. <td>2009/10/22</td>
  327. <td>$114,500</td>
  328. </tr>
  329. <tr>
  330. <td>Prescott Bartlett</td>
  331. <td>Technical Author</td>
  332. <td>London</td>
  333. <td>27</td>
  334. <td>2011/05/07</td>
  335. <td>$145,000</td>
  336. </tr>
  337. <tr>
  338. <td>Gavin Cortez</td>
  339. <td>Team Leader</td>
  340. <td>San Francisco</td>
  341. <td>22</td>
  342. <td>2008/10/26</td>
  343. <td>$235,500</td>
  344. </tr>
  345. <tr>
  346. <td>Martena Mccray</td>
  347. <td>Post-Sales support</td>
  348. <td>Edinburgh</td>
  349. <td>46</td>
  350. <td>2011/03/09</td>
  351. <td>$324,050</td>
  352. </tr>
  353. <tr>
  354. <td>Unity Butler</td>
  355. <td>Marketing Designer</td>
  356. <td>San Francisco</td>
  357. <td>47</td>
  358. <td>2009/12/09</td>
  359. <td>$85,675</td>
  360. </tr>
  361. <tr>
  362. <td>Howard Hatfield</td>
  363. <td>Office Manager</td>
  364. <td>San Francisco</td>
  365. <td>51</td>
  366. <td>2008/12/16</td>
  367. <td>$164,500</td>
  368. </tr>
  369. <tr>
  370. <td>Hope Fuentes</td>
  371. <td>Secretary</td>
  372. <td>San Francisco</td>
  373. <td>41</td>
  374. <td>2010/02/12</td>
  375. <td>$109,850</td>
  376. </tr>
  377. <tr>
  378. <td>Vivian Harrell</td>
  379. <td>Financial Controller</td>
  380. <td>San Francisco</td>
  381. <td>62</td>
  382. <td>2009/02/14</td>
  383. <td>$452,500</td>
  384. </tr>
  385. <tr>
  386. <td>Timothy Mooney</td>
  387. <td>Office Manager</td>
  388. <td>London</td>
  389. <td>37</td>
  390. <td>2008/12/11</td>
  391. <td>$136,200</td>
  392. </tr>
  393. <tr>
  394. <td>Jackson Bradshaw</td>
  395. <td>Director</td>
  396. <td>New York</td>
  397. <td>65</td>
  398. <td>2008/09/26</td>
  399. <td>$645,750</td>
  400. </tr>
  401. <tr>
  402. <td>Olivia Liang</td>
  403. <td>Support Engineer</td>
  404. <td>Singapore</td>
  405. <td>64</td>
  406. <td>2011/02/03</td>
  407. <td>$234,500</td>
  408. </tr>
  409. <tr>
  410. <td>Bruno Nash</td>
  411. <td>Software Engineer</td>
  412. <td>London</td>
  413. <td>38</td>
  414. <td>2011/05/03</td>
  415. <td>$163,500</td>
  416. </tr>
  417. <tr>
  418. <td>Sakura Yamamoto</td>
  419. <td>Support Engineer</td>
  420. <td>Tokyo</td>
  421. <td>37</td>
  422. <td>2009/08/19</td>
  423. <td>$139,575</td>
  424. </tr>
  425. <tr>
  426. <td>Thor Walton</td>
  427. <td>Developer</td>
  428. <td>New York</td>
  429. <td>61</td>
  430. <td>2013/08/11</td>
  431. <td>$98,540</td>
  432. </tr>
  433. <tr>
  434. <td>Finn Camacho</td>
  435. <td>Support Engineer</td>
  436. <td>San Francisco</td>
  437. <td>47</td>
  438. <td>2009/07/07</td>
  439. <td>$87,500</td>
  440. </tr>
  441. <tr>
  442. <td>Serge Baldwin</td>
  443. <td>Data Coordinator</td>
  444. <td>Singapore</td>
  445. <td>64</td>
  446. <td>2012/04/09</td>
  447. <td>$138,575</td>
  448. </tr>
  449. <tr>
  450. <td>Zenaida Frank</td>
  451. <td>Software Engineer</td>
  452. <td>New York</td>
  453. <td>63</td>
  454. <td>2010/01/04</td>
  455. <td>$125,250</td>
  456. </tr>
  457. <tr>
  458. <td>Zorita Serrano</td>
  459. <td>Software Engineer</td>
  460. <td>San Francisco</td>
  461. <td>56</td>
  462. <td>2012/06/01</td>
  463. <td>$115,000</td>
  464. </tr>
  465. <tr>
  466. <td>Jennifer Acosta</td>
  467. <td>Junior Javascript Developer</td>
  468. <td>Edinburgh</td>
  469. <td>43</td>
  470. <td>2013/02/01</td>
  471. <td>$75,650</td>
  472. </tr>
  473. <tr>
  474. <td>Cara Stevens</td>
  475. <td>Sales Assistant</td>
  476. <td>New York</td>
  477. <td>46</td>
  478. <td>2011/12/06</td>
  479. <td>$145,600</td>
  480. </tr>
  481. <tr>
  482. <td>Hermione Butler</td>
  483. <td>Regional Director</td>
  484. <td>London</td>
  485. <td>47</td>
  486. <td>2011/03/21</td>
  487. <td>$356,250</td>
  488. </tr>
  489. <tr>
  490. <td>Lael Greer</td>
  491. <td>Systems Administrator</td>
  492. <td>London</td>
  493. <td>21</td>
  494. <td>2009/02/27</td>
  495. <td>$103,500</td>
  496. </tr>
  497. <tr>
  498. <td>Jonas Alexander</td>
  499. <td>Developer</td>
  500. <td>San Francisco</td>
  501. <td>30</td>
  502. <td>2010/07/14</td>
  503. <td>$86,500</td>
  504. </tr>
  505. <tr>
  506. <td>Shad Decker</td>
  507. <td>Regional Director</td>
  508. <td>Edinburgh</td>
  509. <td>51</td>
  510. <td>2008/11/13</td>
  511. <td>$183,000</td>
  512. </tr>
  513. <tr>
  514. <td>Michael Bruce</td>
  515. <td>Javascript Developer</td>
  516. <td>Singapore</td>
  517. <td>29</td>
  518. <td>2011/06/27</td>
  519. <td>$183,000</td>
  520. </tr>
  521. <tr>
  522. <td>Donna Snider</td>
  523. <td>Customer Support</td>
  524. <td>New York</td>
  525. <td>27</td>
  526. <td>2011/01/25</td>
  527. <td>$112,000</td>
  528. </tr>
  529. </tbody>
  530. </table>
  531. <ul class="tabs">
  532. <li class="active">Javascript</li>
  533. <li>HTML</li>
  534. <li>CSS</li>
  535. <li>Ajax</li>
  536. <li>Server-side script</li>
  537. </ul>
  538. <div class="tabs">
  539. <div class="js">
  540. <p>The Javascript shown below is used to initialise the table shown in this
  541. example:</p><code class="multiline brush: js;">$(document).ready(function() {
  542. var table = $('#example').dataTable();
  543. new $.fn.dataTable.AutoFill( table, {
  544. columnDefs: [ {
  545. targets: -1,
  546. step: function ( cell, read, last, i, x, y ) {
  547. var val = parseInt( (last || read).replace(/[$,]/g, ''), 10 );
  548. val += (x&lt;0 || y&lt;0 ? -100 : 100); // - if going back up, + if going down
  549. // Format for the currency column
  550. return '$'+val.toString().replace( /\B(?=(\d{3})+(?!\d))/g, ',' );
  551. }
  552. } ]
  553. } );
  554. } );</code>
  555. <p>In addition to the above code, the following Javascript library files are loaded for use in this
  556. example:</p>
  557. <ul>
  558. <li><a href="../../../media/js/jquery.js">../../../media/js/jquery.js</a></li>
  559. <li><a href=
  560. "../../../media/js/jquery.dataTables.js">../../../media/js/jquery.dataTables.js</a></li>
  561. <li><a href="../js/dataTables.autoFill.js">../js/dataTables.autoFill.js</a></li>
  562. </ul>
  563. </div>
  564. <div class="table">
  565. <p>The HTML shown below is the raw HTML table element, before it has been enhanced by
  566. DataTables:</p>
  567. </div>
  568. <div class="css">
  569. <div>
  570. <p>This example uses a little bit of additional CSS beyond what is loaded from the library
  571. files (below), in order to correctly display the table. The additional CSS used is shown
  572. below:</p><code class="multiline brush: js;"></code>
  573. </div>
  574. <p>The following CSS library files are loaded for use in this example to provide the styling of the
  575. table:</p>
  576. <ul>
  577. <li><a href=
  578. "../../../media/css/jquery.dataTables.css">../../../media/css/jquery.dataTables.css</a></li>
  579. <li><a href="../css/dataTables.autoFill.css">../css/dataTables.autoFill.css</a></li>
  580. </ul>
  581. </div>
  582. <div class="ajax">
  583. <p>This table loads data by Ajax. The latest data that has been loaded is shown below. This data
  584. will update automatically as any additional data is loaded.</p>
  585. </div>
  586. <div class="php">
  587. <p>The script used to perform the server-side processing for this table is shown below. Please note
  588. that this is just an example script using PHP. Server-side processing scripts can be written in any
  589. language, using <a href="//datatables.net/manual/server-side">the protocol described in the
  590. DataTables documentation</a>.</p>
  591. </div>
  592. </div>
  593. </section>
  594. </div>
  595. <section>
  596. <div class="footer">
  597. <div class="gradient"></div>
  598. <div class="liner">
  599. <h2>Other examples</h2>
  600. <div class="toc">
  601. <div class="toc-group">
  602. <h3><a href="./index.html">Examples</a></h3>
  603. <ul class="toc active">
  604. <li><a href="./simple.html">Basic initialisation</a></li>
  605. <li><a href="./columns.html">Column options</a></li>
  606. <li><a href="./scrolling.html">Scrolling DataTable</a></li>
  607. <li><a href="./fill-both.html">Horizontal and vertical fill</a></li>
  608. <li><a href="./fill-horizontal.html">Horizontal fill</a></li>
  609. <li><a href="./complete-callback.html">Complete callback</a></li>
  610. <li class="active"><a href="./step-callback.html">Step callback</a></li>
  611. </ul>
  612. </div>
  613. </div>
  614. <div class="epilogue">
  615. <p>Please refer to the <a href="http://www.datatables.net">DataTables documentation</a> for full
  616. information about its API properties and methods.<br>
  617. Additionally, there are a wide range of <a href="http://www.datatables.net/extras">extras</a> and
  618. <a href="http://www.datatables.net/plug-ins">plug-ins</a> which extend the capabilities of
  619. DataTables.</p>
  620. <p class="copyright">DataTables designed and created by <a href=
  621. "http://www.sprymedia.co.uk">SpryMedia Ltd</a> &#169; 2007-2014<br>
  622. DataTables is licensed under the <a href="http://www.datatables.net/mit">MIT license</a>.</p>
  623. </div>
  624. </div>
  625. </div>
  626. </section>
  627. </body>
  628. </html>