2.3 KiB
title | description | categories | keywords | action | |||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Menus | Returns a collection of menu objects for the given site. |
|
The Menus
method on a Site
object returns a collection of menus, where each menu contains one or more entries, either flat or nested. Each entry points to a page within the site, or to an external resource.
{{% note %}} Menus can be defined and localized in several ways. Please see the menus section for a complete explanation and examples.
{{% /note %}}
A site can have multiple menus. For example, a main menu and a footer menu:
{{< code-toggle file=hugo >}} menu.main name = 'Home' pageRef = '/' weight = 10
menu.main name = 'Books' pageRef = '/books' weight = 20
menu.main name = 'Films' pageRef = '/films' weight = 30
menu.footer name = 'Legal' pageRef = '/legal' weight = 10
menu.footer name = 'Privacy' pageRef = '/privacy' weight = 20 {{< /code-toggle >}}
This template renders the main menu:
{{ with site.Menus.main }}
<nav class="menu">
{{ range . }}
{{ if $.IsMenuCurrent .Menu . }}
<a class="active" aria-current="page" href="{{ .URL }}">{{ .Name }}</a>
{{ else }}
<a href="{{ .URL }}">{{ .Name }}</a>
{{ end }}
{{ end }}
</nav>
{{ end }}
When viewing the home page, the result is:
<nav class="menu">
<a class="active" aria-current="page" href="/">Home</a>
<a href="/books/">Books</a>
<a href="/films/">Films</a>
</nav>
When viewing the "books" page, the result is:
<nav class="menu">
<a href="/">Home</a>
<a class="active" aria-current="page" href="/books/">Books</a>
<a href="/films/">Films</a>
</nav>
You will typically render a menu using a partial template. As the active menu entry will be different on each page, use the partial
function to call the template. Do not use the partialCached
function.
The example above is simplistic. Please see the menu templates section for more information.