--- pagination: data: testdata size: 2 testdata: - item1 - item2 - item3 - item4 - item5 - item6 --- {%comment%}pagination.items has the data for the current page{%endcomment%}
Syntax Nunjucks
--- pagination: data: testdata size: 2 testdata: - item1 - item2 - item3 - item4 - item5 - item6 --- {# pagination.items has the data for the current page #}
This example has not yet been added—you can swap to another template language above! Or maybe you want to contribute it? Edit this page
The above example would make three different output files from the template.
Page 1 would have pagination.items set to ['item1', 'item2'].
Page 2 would have pagination.items set to ['item3', 'item4'].
Page 3 would have pagination.items set to ['item5', 'item6'].
But to create a series of links to each of these paginated output templates, we’ll want to use our pagination.pages entries , an array of the pagination.items for each page.
A good way to think about it:
pagination.items is the chunk of data for the current page.
pagination.pages is the chunked page data for all of the pages.
INFO:
While the above example pages over an array of data, the code provided here will operate the same for any paginated data (including objects)!
Starter Example
To create an accessible navigation structure, we want to do our research first!
Alright, you definitely read all of those right? 😇 Here’s some accessible code you definitely would have written yourself after reading those wonderful resources:
This example has not yet been added—you can swap to another template language above! Or maybe you want to contribute it? Edit this page
Syntax Nunjucks
<!-- Don’t copy this code, it’s been simplified for clarity --> {%forpageEntryinpagination.pages%} <ahref="{{pagination.hrefs[loop.index0]}}">Page {{loop.index}}</a> {%endfor%}
This example has not yet been added—you can swap to another template language above! Or maybe you want to contribute it? Edit this page
When size is set to 2, pagination.pages will look like: [['item1', 'item2'], ['item3', 'item4'], ['item5', 'item6']]
Use pageEntry[0] and pageEntry[1] to access the original content.
When size is set to 1, pagination.pages will be the same as the original data: ['item1', 'item2', 'item3', 'item4', 'item5', 'item6']
This example has not yet been added—you can swap to another template language above! Or maybe you want to contribute it? Edit this page
Syntax Nunjucks
<!-- Don’t copy this code, it’s been simplified for clarity --> {%forpageKeyinpagination.pages%} <ahref="{{pagination.hrefs[loop.index0]}}">Page {{loop.index}}</a> {%endfor%}
This example has not yet been added—you can swap to another template language above! Or maybe you want to contribute it? Edit this page
When size is set to 2, pagination.pages will look like: [['key1', 'key2'], ['key3', 'key4'], ['key5', 'key6']]
Use testdata[ pageKey[0] ] and testdata[ pageKey[1] ] to access the original content.
When size is set to 1, pagination.pages will be the keys of the object: ['key1', 'key2', 'key3', 'key4', 'key5', 'key6']
Use testdata[ pageKey ] to access the original content.
Visually Style the Current Page Link
You’ll probably also want to add some kind of visual styling to indicate that the user is on the current page. For this let’s use a light background-color.
Syntax CSS
[aria-current]{ background-color: #eee; }
INFO:
A Tip to avoid something that annoys Zach™: If you use something like font-weight here make sure the change in text size for the current page doesn’t make your navigation shift around between pages! This is especially important if your navigation links are displayed side-by-side on the same line.
Add Previous and Next Links
Note that if the current page (page.url) is the first or last in the set, we won’t output links.
pagination.href.previous and pagination.href.next are added in 0.10.0. Use pagination.previousPageHref or pagination.nextPageHref in previous versions.
Add First and Last Links
For clarity here, we’re omitting the previous and next links from the previous section. Note the code below to show the links only if pagination.href.first and pagination.href.last don’t match the current page.url.