× Search About Posts Code Music Links
Blank Try
experiment
lots
learn
more

Hugo Markdown Attributes

Updated on
Last site update: 8 May 2024

Class value

So a new and useful feature in Hugo is the ability to add id and class attributes to elements in markdown files.

Now this is a kind of test page since I couldn’t get this to work the way it’s described. On headings it was simply a case of adding your class name in a single pair of curlies on the same line as the heading.

1### Class value { .green }

And or other HTML elements (lists, tables etc.) the curlies are meant to go on the next line down. But here it would not work for me.

11. item 1
22. item 2
33. item 3
4{ .green }

Well the fix was in the docs. Just gotta read them through. It turns out the ability to do this is set in the config file under [markup].

The default is:

1  [markup.goldmark.parser.attribute]
2    block = false
3    title = true

So all you have to do is copy that under the markup section of your config (create it if you need to) and then change the line begining with block to true

1block = true

This is something I’ll value a lot and will be adding to config files everywhere. Maybe this will be a default value soon. This only became available in Hugo 0.81 and I’m only 0.86 now as I write.

More

But it’s not just class and id attributes you can add. You can add any regular attribute the same way: {title="Boffdong"} or, as the heading above, { style="background-color: #ddd" }.

BUT there are some limitations. The docs say for now at least you can’t add attributes to list items or table cells or rows. I don’t think you can add them to inline elements either. I tried to add to some bold text but … not happening.

Auto ID tags to headings

Another setting that is switched on by default is auto heading ID’s. This adds an id tag to every heading. The default style is github which seems to be a kebab case version of the text of your heading.

Thus my h3 heading above looks like:

1<h3 id="auto-id-tags-to-headings">Auto ID tags to headings</h3>

The config default is:

1[markup.goldmark.parser]
2   autoHeadingID = true
3   autoHeadingIDType = "github"

Adding CSS to the head of a page

So a style sheet is usually in a seperate file but you can have one in the <head> section of individual pages too. To add CSS rules to the <head> section of a page first add this to your Hugo head partial template. (typically in /layouts/partials/head.html)

Assuming you call your frontmatter variable css (call it what you want though):

1{{ with .Params.css }}
2   <style>
3      {{ range . }}
4      	{{ . | safeCSS }}
5      {{ end }}
6   </style>
7{{ end }}

So the with bit is saying if the page has frontmatter variable called css do this. First add <style> tags. Then inside those go through each variable listed. The dot say put each one here and pipe it to safe CSS (which I think means preserve the curly brackets mostly).

The frontmatter looks like this:

1css:
2- ".green {color: green}"

Just one rule but you can add as many as you want and the range function will output each to a new line in your style tags in <head> section of your page.