Pagination
Help Needed! This Documentation page is in need of review and possible revision. Can you help us out?
We’d greatly appreciate it! 😃👍
Pagination support is built-in to Bridgetown, but it is not enabled by default. You can enable it in the config file using:
pagination:
enabled: true
Page Configuration #
To facilitate pagination on any given page (like index.html
, blog.md
, etc.) then include configuration in the resource’s front matter to specify which collection you’d like to paginate through:
---
layout: page
paginate:
collection: posts
---
Then you can use the paginator.resources
logic to iterate through the collection’s resources.
{% for post in paginator.resources %}
<h1>{{ post.data.title }}</h1>
{% endfor %}
By default, paginated pages will have 10 items per page. You can change this in your config by modifying the per_page
key like so:
paginate:
collection: posts
per_page: 4
You can also control the sort field and order of the paginated result set separately from the default sort of the collection:
paginate:
collection: movies
sort_field: rating
sort_reverse: true
Excluding a Resource from the Paginator #
You can exclude a resource from being included in the paginated items list.
exclude_from_pagination: true
Pagination Links #
To display pagination links, use the paginator
Liquid object as follows:
{% if paginator.total_pages > 1 %}
<ul class="pagination">
{% if paginator.previous_page %}
<li>
<a href="{{ paginator.previous_page_path }}">Previous Page</a>
</li>
{% endif %}
{% if paginator.next_page %}
<li>
<a href="{{ paginator.next_page_path }}">Next Page</a>
</li>
{% endif %}
</ul>
{% endif %}
Liquid Attributes Available #
The paginator
Liquid object provides the following attributes:
Variable | Description |
---|---|
|
The number of the current page |
|
Number of resources per page |
|
Resources (aka posts, etc.) available for the current page |
|
Total number of resources |
|
Total number of paginated pages |
|
The number of the previous page, or |
|
The path to the previous page, or |
|
The number of the next page, or |
|
The path to the next page, or |