Schrek.fr

Mon super blog :)

  1. home
  2. posts
  3. 2023
  4. 05
  5. Hugo_menu

Hugo - Création d’un menu

Cet article fait partie de la série: Hugo


Table des matières

On va rajouter un menu a notre template.

Intro

On pourrait passer par le HTML en ajoutant dans le header ou dans un fichier partial/nav.html et en l’ajoutant dans le base_of.html.

<nav> 
 <ul> 
  <li><a href="/">Home</a></li> 
  <li><a href="/about">About</a></li> 
  <li><a href="/contact">Contact</a></li> 
 </ul> 
</nav>

Mais Hugo permet de faire plus efficace. il faut créer dans themes/MONTHEME/layouts/partials/ un fichier nav.html.

<nav>
 <ul>
  {{ range .Site.Menus.main }}
   <li><a href="{{ .URL }}">{{ .Name }}</a></li>
  {{ end }}
 </ul>
</nav>

Explication

On demande a Hugo de regarder dans le fichier de configuration config.toml, s’il y a un Menus.main et de lister ce qu’il y a en argument.

On ajoute ça a la suite de notre config.toml (celui a la racine du site) pour lui indiquer notre menu.

[menu]
[[menu.main]]
  name = 'Home'
  url = '/'
  weight = 10
[[menu.main]]
  name = 'About'
  url = 'pages/about/'
  weight = 20

Pour insérer le menu dans le template on va le rajouter a header.html dans le dossier /themes/MONTHEME/layouts/partials.

<header>
<h1 class="titre">{{ .Site.Title }}</h1>
<h2 class="soustitre">{{ .Site.Params.description }}</h2>
        {{- partial "nav.html" . -}}
</header>

CSS

un coup de CSS pour aligner tous ça dans le dossier schrek.fr/themes/hugo-latex/static/css/style.css.

nav ul li {
       display: inline;
	list-style: none;

}
nav li::before {
     content: ""; 
     padding-right: 2rem;
}

Résultat

On se replace à la racine du projet pour lancer, les options permettent de voir les modifications en direct.

$ hugo serve --noHTTPCache --ignoreCache --disableFastRender

https://schrek.fr/hugo1/

Lien

https://bout2code.fr/tutos/creer-un-site-avec-hugo/

comments powered by Disqus