1
1
mirror of https://github.com/primer/css.git synced 2025-01-07 14:58:54 +03:00
css/docs/content/components/pagination.md

50 lines
1.9 KiB
Markdown
Raw Normal View History

2019-07-30 02:56:17 +03:00
---
title: Pagination
path: components/pagination
2019-08-15 00:59:37 +03:00
status: New
2019-07-30 02:56:17 +03:00
source: 'https://github.com/primer/css/tree/master/src/pagination'
bundle: pagination
---
Use the pagination component to apply button styles to a connected set of links that go to related pages (for example, previous, next, or page numbers).
## Previous/next pagination
You can make a very simple pagination container with just the Previous and Next buttons. Add the class `disabled` to the `Previous` button if there isn't a preceding page, or to the `Next` button if there isn't a succeeding page.
2019-08-09 01:24:04 +03:00
```html live
2019-07-30 02:56:17 +03:00
<nav class="paginate-container" aria-label="Pagination">
<div class="pagination">
<span class="previous_page disabled">Previous</span>
<a class="next_page" rel="next" href="#url" aria-label="Next Page">Next</a>
</div>
</nav>
```
## Numbered pagination
For pagination across multiple pages, make sure it's clear to the user where they are in a set of pages.
2019-12-27 05:33:48 +03:00
To do this, add anchor links to the `pagination` element. Previous and Next buttons should always be present. Add the class `disabled` to the Previous button if you're on the first page. Apply the `aria-current="page"` attribute to the current numbered page.
2019-07-30 02:56:17 +03:00
As always, make sure to include the appropriate `aria` attributes to make the element accessible.
- Add `aria-label="Pagination"` to the the `paginate-container` element.
- Add `aria-label="Page X"` to each anchor link.
2019-08-09 01:24:04 +03:00
```html live
2019-07-30 02:56:17 +03:00
<nav class="paginate-container" aria-label="Pagination">
<div class="pagination">
<span class="previous_page disabled">Previous</span>
2019-12-27 05:33:48 +03:00
<em aria-current="page">1</em>
2019-07-30 02:56:17 +03:00
<a href="#url" aria-label="Page 2">2</a>
<a href="#url" aria-label="Page 3">3</a>
<span class="gap"></span>
<a href="#url" aria-label="Page 8">8</a>
<a href="#url" aria-label="Page 9">9</a>
<a href="#url" aria-label="Page 10">10</a>
<a class="next_page" rel="next" href="#url" aria-label="Next Page">Next</a>
</div>
</nav>
```