Pagination
Navigate between pages of results
Last updated
Navigate between pages of results
Last updated
The pagination pattern allows a user to navigate back and forwards through a URL based dataset, or jump directly to any specific URL in that set.
The pattern is typically used for pagination of search results.
You can take a look at the pagination pattern in action on our examples site.
You can get an idea of the required markup structure by viewing our bones project.
You can see a fully-styled implementation by viewing our eBay Skin example.
Pagination: the composite pattern as a whole, containing the items defined below
Previous: Link that navigates to previous page of results
Next: Link that navigates to next page of results
Items: Links that navigate to exact page of results
Bookends: Collective name for the previous and next links, as they 'bookend' the navigation items
Current Page: The current resultset index, as reflected in the pagination UI
Client-Side Pagination: Pagination links trigger page content updates via AJAX
Server-Side Pagination: Pagination links trigger page content updates via full page reload
Pagination may update the results immediately on the client via AJAX, or on the server via a full page reload. In both cases, the browser's URL will be updated to reflect the new, book-markable page of results.
Do not use buttons for URL based pagination. Because the URL is updated, and the browser history stack updated, a link is the correct tag to use.
Pagination must have a heading element. For example "Results Pagination". This heading can be hidden offscreen for sighted users.
Items must be marked up as a list of links (not buttons).
Bookends must be marked up as links (not buttons).
Bookend icons should be created using SVG.
This section provides the pattern interaction design for keyboard, screen reader & pointing devices.
The bookend and item links must be keyboard focusable at all times (even when visually disabled).
If Previous bookend has keyboard focus, pressing TAB key must move focus to first pagination link.
If pagination item has keyboard focus, pressing TAB key must move focus to next pagination item.
If last pagination item has keyboard focus, pressing TAB key must move focus to Next bookend link.
For client-side pagination, keyboard focus must remain on the previous, next or item link after activation.
Bookend link text must be announced (i.e. "Previous page" and "Next page").
If bookend links are visually disabled, they must also be announced as disabled.
If a pagination item is visually displayed as the current page, it must also be announced as the current page.
For client-side pagination, the new page index must be announced after previous, next or item link activation.
Server-side pagination requires no JavaScript, pagination is simply a collection of links inside of a navigation landmark region.
JavaScript may be used to enhance this baseline behavior, so that the page renders the new result set without a full page reload.
To quickly get an idea of the required markup, visit the pagination bones.
We will step through the creation process for server-side pagination.
Navigation Landmark
We will house the pagination in a navigation landmark, with heading:
The heading doesn't have to go inside of the nav, it could be placed just before. Likewise there is no requirement that the heading be 'clipped' (hidden to sighted users) - but this is usually the case.
Navigation landmarks are even more useful when labelled. So let's go ahead and use the heading text as the label of the landmark:
Bookends
Our previous and next links are going to 'bookend' the navigation items:
Pagination Items
The pagination items are represented as a list of links:
State
There are three aspects of state that must be reflected visually and semantically.
The state of the heading - the heading region can also be used to give a "quickview" of the current page (rather than having to traverse through the all the items to find out)
The state of the bookends - are we at the beginning or end of the resultset?
The state of the items - which item reflects the current page
Heading State
The heading can be used to let us quickly know which page we are currently on. This can be achieved by suffixing the header text:
Bookend State
Assuming that the current pagination index is 0 (i.e the first item in the result set), here is how the first bookend would be marked up:
Because we typically 'grey-out' the first bookend in this state, the aria-disabled
attribute has been added to convey this state semantically to assistive technology. We call this a partially disabled link and should only be used in case where two links (or buttons) bookend a list of items (e.g. in a carousel or pagination pattern)
Item State
And here is how the first item would be marked up:
Again, this item would be typically styled visually to reflect its 'current item' status. The aria-current
attribute allows us to do the same semantically for assistive technology.
HTML Checkpoint
At this point we now have a pagination control that works without CSS and JavaScript.
Here is a recap of the final HTML:
There are no special considerations for accessibility when it comes to styling pagination. You should however try and make use of the aria-current
and aria-disabled
attribute hooks, rather than inventing classes.
Server-side pagination requires no JavaScript, it is simply a collection of links. Clicking any link reloads the entire page. This experience can be enhanced with JavaScript, so that only the results portion of the screen is re-rendered.
Client-Side Pagination
It is outside the scope of this guide to write all of the JavaScript behaviour for a partial page update, but the snippet below gives a rough idea of the steps required.
This section gives an overview of our use of ARIA, within the specific context of this pattern.
Creates a navigation landmark for assistive technology.
Applied to bookend SVG tags to reinforce image semantics.
Use this property to label the navigation landmark with the text of the heading tag.
aria-disabled
Use this property on the bookend anchor to convey when it is "greyed-out"
aria-label
Use this property to label the bookend anchors.
Refers to the current item in the pagination (i.e. the current dataset index).