This example demonstrates the various configuration options for the YAHOO.widget.Paginator class included with the DataTable. Note that all navigation in the left column is generated by the Paginator.
California - Connecticut
State | Code |
---|
State | Code |
---|---|
California | 714 |
California | 760 |
California | 805 |
California | 818 |
California | 831 |
California | 858 |
California | 909 |
California | 916 |
California | 925 |
California | 949 |
Cayman Islands | 345 |
CNMI | 670 |
Colorado | 303 |
Colorado | 719 |
Colorado | 720 |
Colorado | 970 |
Connecticut | 203 |
Connecticut | 475 |
Connecticut | 860 |
Connecticut | 959 |
Loading data... |
Besides the normal configurations for pagination, we'll demonstrate the use of the other Paginator configuration options. Most notably, we'll use the template
and pageLabelBuilder
options to render the pagination controls in a custom layout with more descriptive page links.
1 | <div id="demo"> |
2 | <div id="pag"></div> |
3 | <div id="tbl"></div> |
4 | </div> |
view plain | print | ? |
1 | #demo { |
2 | width: 525px; |
3 | } |
4 | #pag { |
5 | display: inline; |
6 | float: left; |
7 | width: 250px; |
8 | margin-top: 0; |
9 | } |
10 | #pag a { |
11 | color: #0000de; |
12 | text-decoration: underline; |
13 | padding: .5ex 0; |
14 | } |
15 | #pag label { |
16 | display: block; |
17 | margin: 1ex 0; |
18 | } |
19 | #pag p { |
20 | margin: .25ex 0; |
21 | } |
22 | |
23 | .yui-skin-sam #pag .yui-pg-pages { |
24 | display: block; |
25 | } |
26 | .yui-skin-sam #pag .yui-pg-page { |
27 | display: block; |
28 | background-color: #f1f6f7; |
29 | background: transparent; |
30 | border: none; |
31 | white-space: normal; |
32 | } |
33 | .yui-skin-sam #pag .yui-pg-current-page { |
34 | padding: .5ex 0; |
35 | background-color: #ffe; |
36 | font-style: italic; |
37 | } |
38 | .yui-skin-sam #pag .yui-pg-current { |
39 | margin: 0; |
40 | white-space: normal; |
41 | font-weight: bold; |
42 | font-size: 113%; |
43 | } |
44 | .yui-skin-sam #demo .yui-dt caption { |
45 | margin: 0.2em 0 0; |
46 | color: #e76300; |
47 | font-weight: bold; |
48 | } |
view plain | print | ? |
We'll start by making sure our data is in order, then define the function that we'll use to populate the page links.
1 | YAHOO.util.Event.onDOMReady(function () { |
2 | |
3 | // Sort our data by state, then area code |
4 | var Data = YAHOO.example.Data.areacodes; |
5 | Data.sort(function (a,b) { |
6 | return YAHOO.util.Sort.compare(a.state,b.state) || |
7 | YAHOO.util.Sort.compare(a.areacode,b.areacode); |
8 | }); |
9 | |
10 | // Custom function we'll use to create the page links |
11 | var buildPageLabel = function (recs) { |
12 | var start = recs[0], |
13 | end = recs[1]; |
14 | |
15 | // Nested function to find the smallest substring |
16 | // to indicate how two strings differ |
17 | var diffNames = function (a,b) { |
18 | var aa = a.state.toLowerCase(), |
19 | bb = b.state.toLowerCase(); |
20 | |
21 | for (var i = 0, len = aa.length; i < len; ++i) { |
22 | if (aa.charAt(i) !== bb.charAt(i)) { |
23 | return a.state.substr(0,i+1); |
24 | } |
25 | } |
26 | |
27 | return a.state + ' ('+a.areacode+')'; |
28 | }; |
29 | |
30 | // Build label as "A - C" or "Abc - Def" |
31 | var label = ''; |
32 | if (!start) { |
33 | label = Data[0].state.substr(0,2) + ' - '; |
34 | } else { |
35 | label = diffNames(Data[start], Data[start-1]) + ' - '; |
36 | } |
37 | |
38 | if (Data[end+1]) { |
39 | label += diffNames(Data[end], Data[end+1]); |
40 | } else { |
41 | label += diffNames(Data[end], Data[start]); |
42 | } |
43 | |
44 | return label; |
45 | }; |
view plain | print | ? |
We'll assign something to every available Paginator configuration key, if even the default value, just for illustration.
1 | // Paginator configurations |
2 | var myPaginatorConfig = { |
3 | // REQUIRED |
4 | rowsPerPage : 20, |
5 | |
6 | // REQUIRED, but DataTable will default if not provided |
7 | containers : 'pag', |
8 | |
9 | // If not provided, there is no last page or total pages. |
10 | // DataTable will set this in the DataSource callback, so this is |
11 | // redundant. |
12 | totalRecords : Data.length, |
13 | |
14 | // page to activate at load |
15 | initialPage : 3, |
16 | |
17 | // Class the element(s) that will contain the controls |
18 | containerClass : 'yui-pg-container', // default |
19 | |
20 | // Define the innerHTML of the container(s) using placeholders |
21 | // to identify where the controls will be located |
22 | template : |
23 | '<h3>Now showing:</h3>' + |
24 | '<p>{CurrentPageReport}</p>' + |
25 | '<p class="pg-nav">' + |
26 | '{FirstPageLink} {PreviousPageLink} ' + |
27 | '{NextPageLink} {LastPageLink}' + |
28 | '</p>' + |
29 | '<label>Page size: {RowsPerPageDropdown}</label>' + |
30 | '<h3>Directory</h3>' + |
31 | '{PageLinks}', |
32 | |
33 | // If there is less data than would display on one page, pagination |
34 | // controls can be omitted by setting this to false. |
35 | alwaysVisible : true, // default |
36 | |
37 | // Override setPage (et al) to immediately update internal values |
38 | // and update the pagination controls in response to user actions. |
39 | // Default is false; requests are delegated through the changeRequest |
40 | // event subscriber. |
41 | updateOnChange : false, // default |
42 | |
43 | // Options for FirstPageLink component |
44 | firstPageLinkLabel : "<<", |
45 | firstPageLinkClass : "yui-pg-first", // default |
46 | |
47 | // Options for LastPageLink component |
48 | lastPageLinkLabel : ">>", |
49 | lastPageLinkClass : "yui-pg-last", // default |
50 | |
51 | // Options for PreviousPageLink component |
52 | previousPageLinkLabel : "< previous", |
53 | previousPageLinkClass : "yui-pg-previous", // default |
54 | |
55 | // Options for NextPageLink component |
56 | nextPageLinkLabel : "next >", // default |
57 | nextPageLinkClass : "yui-pg-next", // default |
58 | |
59 | // Options for PageLinks component |
60 | pageLinksContainerClass : 'yui-pg-pages', // default |
61 | pageLinkClass : 'yui-pg-page', // default |
62 | currentPageClass : 'yui-pg-current-page', // default |
63 | |
64 | // Display a maximum of X page links at a time. Use |
65 | // YAHOO.widget.Paginator.VALUE_UNLIMITED to show all page links |
66 | pageLinks : YAHOO.widget.Paginator.VALUE_UNLIMITED, |
67 | |
68 | // Create custom page link labels |
69 | pageLabelBuilder : function (page,paginator) { |
70 | return buildPageLabel(paginator.getPageRecords(page)); |
71 | }, |
72 | |
73 | // Options for RowsPerPageDropdown component |
74 | rowsPerPageDropdownClass : "yui-pg-rpp-options", // default |
75 | rowsPerPageOptions : [ |
76 | { value : 20, text : "small" }, |
77 | { value : 40, text : "medium" }, |
78 | { value : 100, text : "large" } |
79 | ], |
80 | |
81 | // Options for CurrentPageReport component |
82 | pageReportClass : 'yui-pg-current', // default |
83 | |
84 | // Provide a key:value map for use by the pageReportTemplate. |
85 | // Unlikely this will need to be customized; see API docs for the |
86 | // template keys made available by the default value generator |
87 | pageReportValueGenerator : function (paginator) { |
88 | var recs = paginator.getPageRecords(); |
89 | |
90 | return { |
91 | start : Data[recs[0]].state, |
92 | end : Data[recs[1]].state |
93 | }; |
94 | }, |
95 | |
96 | // How to render the notification of the Paginator's current state |
97 | pageReportTemplate : '{start} - {end}' |
98 | }; |
99 | |
100 | // Create the Paginator for our DataTable to use |
101 | var myPaginator = new YAHOO.widget.Paginator(myPaginatorConfig); |
view plain | print | ? |
Beyond this, it's simply a matter of creating your DataTable as normal.
1 | // Normal DataTable configuration |
2 | var myColumnDefs = [ {key:"state", label:"State", minWidth: 150}, |
3 | {key:"areacode", label:"Code", width: 30}]; |
4 | |
5 | var myDataSource = new YAHOO.util.DataSource(Data); |
6 | myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSARRAY; |
7 | myDataSource.responseSchema = { |
8 | fields : ["state","areacode"] |
9 | }; |
10 | |
11 | // Pass the Paginator in the DataTable config |
12 | var myTableConfig = { |
13 | paginator : myPaginator, |
14 | caption : 'Area Codes by State' |
15 | }; |
16 | |
17 | var myDataTable = new YAHOO.widget.DataTable('tbl', |
18 | myColumnDefs, myDataSource, myTableConfig); |
view plain | print | ? |
INFO3351ms (+17) 4:29:38 PM:DataTable instance yui-dt0
DataTable initialized with 20 of 328 rows
INFO3334ms (+3) 4:29:38 PM:DataTable instance yui-dt0
DataTable message hidden
INFO3331ms (+0) 4:29:38 PM:DataTable instance yui-dt0
DataTable rendering...
INFO3331ms (+1) 4:29:38 PM:DataTable instance yui-dt0
DataTable showing message: Loading data...
INFO3330ms (+2) 4:29:38 PM:RecordSet instance yui-rs0
Set 328 Record(s) at index 0
INFO3328ms (+3) 4:29:38 PM:DataSource instance0
Parsed array data is {results => [{areacode => 205, state => Alabama}, {areacode => 251, state => Alabama}, {areacode => 256, state => Alabama}, {areacode => 334, state => Alabama}, {areacode => 907, state => Alaska}, {areacode => 403, state => Alberta, Canada}, {areacode => 780, state => Alberta, Canada}, {areacode => 264, state => Anguilla}, {areacode => 268, state => Antigua and Barbuda}, {areacode => 480, state => Arizona}, {areacode => 520, state => Arizona}, {areacode => 602, state => Arizona}, {areacode => 623, state => Arizona}, {areacode => 928, state => Arizona}, {areacode => 479, state => Arkansas}, {areacode => 501, state => Arkansas}, {areacode => 870, state => Arkansas}, {areacode => 242, state => Bahamas}, {areacode => 246, state => Barbados}, {areacode => 441, state => Bermuda}, {areacode => 250, state => British Columbia}, {areacode => 604, state => British Columbia, Canada}, {areacode => 778, state => British Columbia, Canada}, {areacode => 284, state => British Virgin Islands}, {areacode => 209, state => California}, {areacode => 213, state => California}, {areacode => 310, state => California}, {areacode => 323, state => California}, {areacode => 408, state => California}, {areacode => 415, state => California}, {areacode => 424, state => California}, {areacode => 510, state => California}, {areacode => 530, state => California}, {areacode => 559, state => California}, {areacode => 562, state => California}, {areacode => 619, state => California}, {areacode => 626, state => California}, {areacode => 650, state => California}, {areacode => 661, state => California}, {areacode => 707, state => California}, {areacode => 714, state => California}, {areacode => 760, state => California}, {areacode => 805, state => California}, {areacode => 818, state => California}, {areacode => 831, state => California}, {areacode => 858, state => California}, {areacode => 909, state => California}, {areacode => 916, state => California}, {areacode => 925, state => California}, {areacode => 949, state => California}, {areacode => 345, state => Cayman Islands}, {areacode => 670, state => CNMI}, {areacode => 303, state => Colorado}, {areacode => 719, state => Colorado}, {areacode => 720, state => Colorado}, {areacode => 970, state => Colorado}, {areacode => 203, state => Connecticut}, {areacode => 475, state => Connecticut}, {areacode => 860, state => Connecticut}, {areacode => 959, state => Connecticut}, {areacode => 302, state => Delaware}, {areacode => 767, state => Dominica}, {areacode => 809, state => Dominican Republic}, {areacode => 239, state => Florida}, {areacode => 305, state => Florida}, {areacode => 321, state => Florida}, {areacode => 352, state => Florida}, {areacode => 386, state => Florida}, {areacode => 407, state => Florida}, {areacode => 561, state => Florida}, {areacode => 727, state => Florida}, {areacode => 754, state => Florida}, {areacode => 772, state => Florida}, {areacode => 786, state => Florida}, {areacode => 813, state => Florida}, {areacode => 850, state => Florida}, {areacode => 863, state => Florida}, {areacode => 904, state => Florida}, {areacode => 941, state => Florida}, {areacode => 954, state => Florida}, {areacode => 229, state => Georgia}, {areacode => 404, state => Georgia}, {areacode => 470, state => Georgia}, {areacode => 478, state => Georgia}, {areacode => 678, state => Georgia}, {areacode => 706, state => Georgia}, {areacode => 770, state => Georgia}, {areacode => 912, state => Georgia}, {areacode => 473, state => Grenada}, {areacode => 671, state => Guam}, {areacode => 808, state => Hawaii}, {areacode => 208, state => Idaho}, {areacode => 217, state => Illinois}, {areacode => 224, state => Illinois}, {areacode => 309, state => Illinois}, {areacode => 312, state => Illinois}, {areacode => 331, state => Illinois}, {areacode => 464, state => Illinois}, {areacode => 618, state => Illinois}, {areacode => 630, state => Illinois}, {areacode => 708, state => Illinois}, {areacode => 773, state => Illinois}, {areacode => 815, state => Illinois}, {areacode => 847, state => Illinois}, {areacode => 872, state => Illinois}, {areacode => 219, state => Indiana}, {areacode => 260, state => Indiana}, {areacode => 317, state => Indiana}, {areacode => 574, state => Indiana}, {areacode => 765, state => Indiana}, {areacode => 812, state => Indiana}, {areacode => 319, state => Iowa}, {areacode => 515, state => Iowa}, {areacode => 563, state => Iowa}, {areacode => 641, state => Iowa}, {areacode => 712, state => Iowa}, {areacode => 876, state => Jamaica}, {areacode => 316, state => Kansas}, {areacode => 620, state => Kansas}, {areacode => 785, state => Kansas}, {areacode => 913, state => Kansas}, {areacode => 270, state => Kentucky}, {areacode => 502, state => Kentucky}, {areacode => 606, state => Kentucky}, {areacode => 859, state => Kentucky}, {areacode => 225, state => Louisiana}, {areacode => 318, state => Louisiana}, {areacode => 337, state => Louisiana}, {areacode => 504, state => Louisiana}, {areacode => 985, state => Louisiana}, {areacode => 207, state => Maine}, {areacode => 204, state => Manitoba, Canada}, {areacode => 227, state => Maryland}, {areacode => 240, state => Maryland}, {areacode => 301, state => Maryland}, {areacode => 410, state => Maryland}, {areacode => 443, state => Maryland}, {areacode => 667, state => Maryland}, {areacode => 339, state => Massachusetts}, {areacode => 351, state => Massachusetts}, {areacode => 413, state => Massachusetts}, {areacode => 508, state => Massachusetts}, {areacode => 617, state => Massachusetts}, {areacode => 774, state => Massachusetts}, {areacode => 781, state => Massachusetts}, {areacode => 857, state => Massachusetts}, {areacode => 978, state => Massachusetts}, {areacode => 231, state => Michigan}, {areacode => 248, state => Michigan}, {areacode => 269, state => Michigan}, {areacode => 313, state => Michigan}, {areacode => 517, state => Michigan}, {areacode => 586, state => Michigan}, {areacode => 616, state => Michigan}, {areacode => 734, state => Michigan}, {areacode => 810, state => Michigan}, {areacode => 906, state => Michigan}, {areacode => 947, state => Michigan}, {areacode => 989, state => Michigan}, {areacode => 218, state => Minnesota}, {areacode => 320, state => Minnesota}, {areacode => 507, state => Minnesota}, {areacode => 612, state => Minnesota}, {areacode => 651, state => Minnesota}, {areacode => 763, state => Minnesota}, {areacode => 952, state => Minnesota}, {areacode => 228, state => Mississippi}, {areacode => 601, state => Mississippi}, {areacode => 662, state => Mississippi}, {areacode => 314, state => Missouri}, {areacode => 417, state => Missouri}, {areacode => 557, state => Missouri}, {areacode => 573, state => Missouri}, {areacode => 636, state => Missouri}, {areacode => 660, state => Missouri}, {areacode => 816, state => Missouri}, {areacode => 975, state => Missouri}, {areacode => 406, state => Montana}, {areacode => 664, state => Montserrat}, {areacode => 308, state => Nebraska}, {areacode => 402, state => Nebraska}, {areacode => 702, state => Nevada}, {areacode => 775, state => Nevada}, {areacode => 506, state => New Brunswick, Canada}, {areacode => 603, state => New Hampshire}, {areacode => 201, state => New Jersey}, {areacode => 551, state => New Jersey}, {areacode => 609, state => New Jersey}, {areacode => 732, state => New Jersey}, {areacode => 848, state => New Jersey}, {areacode => 856, state => New Jersey}, {areacode => 862, state => New Jersey}, {areacode => 908, state => New Jersey}, {areacode => 973, state => New Jersey}, {areacode => 505, state => New Mexico}, {areacode => 212, state => New York}, {areacode => 315, state => New York}, {areacode => 347, state => New York}, {areacode => 516, state => New York}, {areacode => 518, state => New York}, {areacode => 585, state => New York}, {areacode => 607, state => New York}, {areacode => 631, state => New York}, {areacode => 646, state => New York}, {areacode => 716, state => New York}, {areacode => 718, state => New York}, {areacode => 845, state => New York}, {areacode => 914, state => New York}, {areacode => 917, state => New York}, {areacode => 709, state => Newfoundland, Canada}, {areacode => 252, state => North Carolina}, {areacode => 336, state => North Carolina}, {areacode => 704, state => North Carolina}, {areacode => 828, state => North Carolina}, {areacode => 910, state => North Carolina}, {areacode => 919, state => North Carolina}, {areacode => 980, state => North Carolina}, {areacode => 984, state => North Carolina}, {areacode => 701, state => North Dakota}, {areacode => 902, state => Nova Scotia, Canada}, {areacode => 216, state => Ohio}, {areacode => 234, state => Ohio}, {areacode => 283, state => Ohio}, {areacode => 330, state => Ohio}, {areacode => 419, state => Ohio}, {areacode => 440, state => Ohio}, {areacode => 513, state => Ohio}, {areacode => 567, state => Ohio}, {areacode => 614, state => Ohio}, {areacode => 740, state => Ohio}, {areacode => 937, state => Ohio}, {areacode => 405, state => Oklahoma}, {areacode => 580, state => Oklahoma}, {areacode => 918, state => Oklahoma}, {areacode => 289, state => Ontario}, {areacode => 416, state => Ontario, Canada}, {areacode => 519, state => Ontario, Canada}, {areacode => 613, state => Ontario, Canada}, {areacode => 647, state => Ontario, Canada}, {areacode => 705, state => Ontario, Canada}, {areacode => 807, state => Ontario, Canada}, {areacode => 905, state => Ontario, Canada}, {areacode => 503, state => Oregon}, {areacode => 541, state => Oregon}, {areacode => 971, state => Oregon}, {areacode => 215, state => Pennsylvania}, {areacode => 267, state => Pennsylvania}, {areacode => 412, state => Pennsylvania}, {areacode => 445, state => Pennsylvania}, {areacode => 484, state => Pennsylvania}, {areacode => 570, state => Pennsylvania}, {areacode => 610, state => Pennsylvania}, {areacode => 717, state => Pennsylvania}, {areacode => 724, state => Pennsylvania}, {areacode => 814, state => Pennsylvania}, {areacode => 835, state => Pennsylvania}, {areacode => 878, state => Pennsylvania}, {areacode => 787, state => Puerto Rico}, {areacode => 939, state => Puerto Rico}, {areacode => 418, state => Quebec, Canada}, {areacode => 450, state => Quebec, Canada}, {areacode => 514, state => Quebec, Canada}, {areacode => 819, state => Quebec, Canada}, {areacode => 401, state => Rhode Island}, {areacode => 306, state => Saskatchewan, Canada}, {areacode => 803, state => South Carolina}, {areacode => 843, state => South Carolina}, {areacode => 864, state => South Carolina}, {areacode => 605, state => South Dakota}, {areacode => 869, state => St. Kitts & Nevis}, {areacode => 758, state => St. Lucia}, {areacode => 784, state => St. Vincent & Gren.}, {areacode => 423, state => Tennessee}, {areacode => 615, state => Tennessee}, {areacode => 731, state => Tennessee}, {areacode => 865, state => Tennessee}, {areacode => 901, state => Tennessee}, {areacode => 931, state => Tennessee}, {areacode => 210, state => Texas}, {areacode => 214, state => Texas}, {areacode => 254, state => Texas}, {areacode => 281, state => Texas}, {areacode => 361, state => Texas}, {areacode => 409, state => Texas}, {areacode => 469, state => Texas}, {areacode => 512, state => Texas}, {areacode => 682, state => Texas}, {areacode => 713, state => Texas}, {areacode => 737, state => Texas}, {areacode => 806, state => Texas}, {areacode => 817, state => Texas}, {areacode => 830, state => Texas}, {areacode => 832, state => Texas}, {areacode => 903, state => Texas}, {areacode => 915, state => Texas}, {areacode => 936, state => Texas}, {areacode => 940, state => Texas}, {areacode => 956, state => Texas}, {areacode => 972, state => Texas}, {areacode => 979, state => Texas}, {areacode => 868, state => Trinidad and Tobago}, {areacode => 649, state => Turks and Caicos Islands}, {areacode => 340, state => US Virgin Islands}, {areacode => 435, state => Utah}, {areacode => 801, state => Utah}, {areacode => 802, state => Vermont}, {areacode => 276, state => Virginia}, {areacode => 434, state => Virginia}, {areacode => 540, state => Virginia}, {areacode => 571, state => Virginia}, {areacode => 703, state => Virginia}, {areacode => 804, state => Virginia}, {areacode => 757, state => Viriginia}, {areacode => 206, state => Washington}, {areacode => 253, state => Washington}, {areacode => 360, state => Washington}, {areacode => 425, state => Washington}, {areacode => 509, state => Washington}, {areacode => 564, state => Washington}, {areacode => 202, state => Washington, DC}, {areacode => 304, state => West Virginia}, {areacode => 262, state => Wisconsin}, {areacode => 414, state => Wisconsin}, {areacode => 608, state => Wisconsin}, {areacode => 715, state => Wisconsin}, {areacode => 920, state => Wisconsin}, {areacode => 307, state => Wyoming}, {areacode => 867, state => Yukon, NW Territories, Canada}]}
INFO3325ms (+1) 4:29:38 PM:DataSource instance0
Received live data response for "null"
INFO3324ms (+3) 4:29:38 PM:DataSource instance0
Making connection to live data for "null"
INFO3321ms (+1) 4:29:38 PM:DataTable instance yui-dt0
DataTable showing message: Loading data...
INFO3320ms (+1) 4:29:38 PM:DataTable instance yui-dt0
Accessibility TH cells for 2keys created
INFO3319ms (+2) 4:29:38 PM:DataTable instance yui-dt0
TH cells for 2 keys created
INFO3317ms (+0) 4:29:38 PM:RecordSet instance yui-rs0
RecordSet initialized
INFO3317ms (+1) 4:29:38 PM:ColumnSet instance yui-cs0
ColumnSet initialized
INFO3316ms (+24) 4:29:38 PM:DataSource instance0
DataSource initialized
INFO3292ms (+3292) 4:29:38 PM:LogReader instance0
LogReader initialized
INFO0ms (+0) 4:29:34 PM:global
Logger initialized
Note: You are viewing this example in debug mode with logging enabled. This can significantly slow performance.
Copyright © 2008 Yahoo! Inc. All rights reserved.
Privacy Policy - Terms of Service - Copyright Policy - Job Openings