mirror of
https://github.com/gohugoio/hugo.git
synced 2024-12-02 00:58:51 -05:00
1.7 KiB
1.7 KiB
Hugo determines the next and previous page by sorting the site's collection of regular pages according to this sorting hierarchy:
Field | Precedence | Sort direction |
---|---|---|
weight |
1 | descending |
date |
2 | descending |
linkTitle |
3 | descending |
path |
4 | descending |
The sorted page collection used to determine the next and previous page is independent of other page collections, which may lead to unexpected behavior.
For example, with this content structure:
content/
├── pages/
│ ├── _index.md
│ ├── page-1.md <-- front matter: weight = 10
│ ├── page-2.md <-- front matter: weight = 20
│ └── page-3.md <-- front matter: weight = 30
└── _index.md
And these templates:
{{< code file=layouts/_default/list.html >}} {{ range .Pages.ByWeight }}
{{ .LinkTitle }}
{{ end }} {{< /code >}}{{< code file=layouts/_default/single.html >}} {{ with .Prev }} Previous {{ end }}
{{ with .Next }} Next {{ end }} {{< /code >}}
When you visit page-2:
- The
Prev
method points to page-3 - The
Next
method points to page-1
To reverse the meaning of next and previous you can change the sort direction in your site configuration, or use the Next
and Prev
methods on a Pages
object for more flexibility.