In this tutorial, we’ll learn how to generate auto-numbering for headings, subheadings, and TOC in Hugo Pages.
Overview
When you generate a website using Hugo static site generator, It doesn’t provide any out of the box auto-numbering support for headings, subheadings, and TOC in Hugo Pages.
This blog website is also generated using Hugo and with few changes, we’re able to add auto-numbering support to our Hugo Pages.
If you’re still not clear what is auto-numbering all about then look at the auto incrementing numbers before the headings, subheadings and TOC in this post i.e. 1,2, 2.1,2.2,2.3 etc.
|
|
Let’s discuss how to enable this feature.
Auto-numbering Pages
Follow these three steps to enable auto-numbering feature in your Hugo website:
Add “autonumbering” property in front-matter
First of all, we’re going to add a custom property autonumbering
in the front-matter of our Hugo pages.
We can enable or disable auto-numbering for a specific page using this property. If autonumbering: true
, means it is enabled otherwise disabled.
|
|
|
|
Add CSS Class to single.html
Next, we are going to edit layouts/_default/single.html file and add a condition on article
element to add autonumbering
CSS class based on autonumbering property is enabled or disabled.
Please note that if you are using any Hugo theme then you can find single.html in themes folder.
|
|
|
|
If autonumbering is enabled on any post. It will look like this:
|
|
If autonumbering is disabled on any post. It will look like this:
|
|
Add CSS Styles to style.css
At last, add the following CSS Styles snippet in the CSS files you would be using in your project. Location of css file may differ in your project.
|
|
|
|
That’s it. You should be able to use autonumbering feature in your hugo pages now.