--- 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(in latest version)
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(in latest version)
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)!
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(in latest version)
Filename starter.njk
<navaria-labelledby="my-pagination"> <h2id="my-pagination">This is my Pagination</h2> <ol> {%- for pageEntry in pagination.pages %} <li><a href="{{ pagination.hrefs[ loop.index0 ] }}"{% if page.url == pagination.hrefs[ loop.index0 ] %} aria-current="page"{% endif %}>Page {{ loop.index }}</a></li> {%- endfor %} </ol> </nav>
Filename starter.11ty.js
exports.render=function(data){ return`<nav aria-labelledby="my-pagination"> <h2 id="my-pagination">This is my Pagination</h2> <ol> ${data.pagination.pages.map(function(item, index){ return`<li><a href="${data.pagination.hrefs[index]}" ${data.pagination.hrefs[index]?'aria-current="page"':""}>Page ${index +1}</a></li>`; }).join("");} </ol> </nav>`; };
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(in latest version)
For our example, this code will output the following markup for our example (on the first page):
Syntax HTML
<navaria-labelledby="my-pagination"> <h2id="my-pagination">This is my Pagination</h2> <ol> <li><ahref="/test/"aria-current="page">Page 1</a></li> <li><ahref="/test/1/">Page 2</a></li> <li><ahref="/test/2/">Page 3</a></li> </ol> </nav>
INFO:
HTML tip: make sure the id attribute used on your heading (id="my-pagination") is unique to your 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(in latest version)
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(in latest version)
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(in latest version)
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(in latest version)
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(in latest version)
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(in latest version)
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.
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.
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(in latest version)
Filename nextprev.njk
<navaria-labelledby="my-pagination"> <h2id="my-pagination">This is my Pagination</h2> <ol> <li>{%ifpagination.href.previous%}<ahref="{{pagination.href.previous}}">Previous</a>{%else%}Previous{%endif%}</li> {%-forpageEntryinpagination.pages%} <li><ahref="{{pagination.hrefs[loop.index0]}}"{%ifpage.url==pagination.hrefs[loop.index0]%}aria-current="page"{%endif%}>Page {{loop.index}}</a></li> {%-endfor%} <li>{%ifpagination.href.next%}<ahref="{{pagination.href.next}}">Next</a>{%else%}Next{%endif%}</li> </ol> </nav>
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(in latest version)
pagination.href.previous and pagination.href.next are added in 0.10.0. Use pagination.previousPageHref or pagination.nextPageHref in previous versions.
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.
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(in latest version)
Filename firstlast.njk
<navaria-labelledby="my-pagination"> <h2id="my-pagination">This is my Pagination</h2> <ol> <li>{%ifpage.url!=pagination.href.first%}<ahref="{{pagination.href.first}}">First</a>{%else%}First{%endif%}</li> {%-forpageEntryinpagination.pages%} <li><ahref="{{pagination.hrefs[loop.index0]}}"{%ifpage.url==pagination.hrefs[loop.index0]%}aria-current="page"{%endif%}>Page {{loop.index}}</a></li> {%-endfor%} <li>{%ifpage.url!=pagination.href.last%}<ahref="{{pagination.href.last}}">Last</a>{%else%}Last{%endif%}</li> </ol> </nav>
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(in latest version)
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(in latest version)
Filename combined.njk
<navaria-labelledby="my-pagination"> <h2id="my-pagination">This is my Pagination</h2> <ol> <li>{%ifpage.url!=pagination.href.first%}<ahref="{{pagination.href.first}}">First</a>{%else%}First{%endif%}</li> <li>{%ifpagination.href.previous%}<ahref="{{pagination.href.previous}}">Previous</a>{%else%}Previous{%endif%}</li> {%-forpageEntryinpagination.pages%} <li><ahref="{{pagination.hrefs[loop.index0]}}"{%ifpage.url==pagination.hrefs[loop.index0]%}aria-current="page"{%endif%}>Page {{loop.index}}</a></li> {%-endfor%} <li>{%ifpagination.href.next%}<ahref="{{pagination.href.next}}">Next</a>{%else%}Next{%endif%}</li> <li>{%ifpage.url!=pagination.href.last%}<ahref="{{pagination.href.last}}">Last</a>{%else%}Last{%endif%}</li> </ol> </nav>
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(in latest version)
Alright, you’ve copied the above—but don’t leave yet—your work is not done (sorry)! You still need to:
Change my-pagination to a better id attribute for your use case and update it in aria-labelledby too.
Update the This is my Pagination text to make more sense for your use case.
Think about maybe changing the <h2> to better suit your document structure.