Aug 22, 2021
Hugo uses chroma[1] as its syntax highlighter. All you basically need for having your code highlighted is to let chroma put the syntax classes in the generated HTML, for the correct language, and then make sure you have corresponding CSS for those classes.
=> 1: https://github.com/alecthomas/chroma
Let's start by enabling syntax highlighting in your configuration file.
In your configuration file, config.toml
for example, add these settings so you can have your code highlighted and have it recognize Fenced Code Blocks for markdown:
pygmentsUseClasses = true pygmentsCodeFences = true
Next you have to include the styles. There are two ways to go about this, one is to choose a style from the list of available styles (more on that below), and the second method is to use your own syntax theme.
You can have your own CSS styles, but there are a lot of classes, so if you're just starting out and want to have it working quickly, you should choose an existing style.
Browse the gallery[2] of available styles and use that style name to save the CSS file into your assets
directory:
=> 2: https://xyproto.github.io/splash/docs/
mkdir -p assets/syntax hugo gen chromastyles --style=friendly > assets/syntax/main.css
If you'd like to use different styles for dark mode and light mode (like me), then you can change "main.css" to "light.css", and save the dark mode style to "dark.css". It doesn't matter where you put the file, but just remember to use that file name with referencing it later.
You don't have to put it under the directory "syntax" too, if you don't want to.
You have to link to your CSS file that you've just created in your <head>
. There are several ways you can do so.
<link>
tag and link to the URL of your CSS file, or<style>
tag.Here's how you can do the second method.
{{- $syntaxCSS := resources.Get "syntax/main.css" | minify -}}
Assuming your CSS file is at assets/syntax/main.css
.
All set for the styling part! Now you can write some content and try it out.
Remember to include the file type when putting code in markdown.
This is not code ```sh # and this is some sh code echo 'hi!' ```
You can have different styles of syntax highlighting for dark mode and light mode.
First you have to export or save your CSS for dark mode and light mode in separate files. Then, change the part in your <head>
where you've included the styles:
{{- $syntaxlight := resources.Get "syntax/light.css" | minify -}} {{- $syntaxdark := resources.Get "syntax/dark.css" | minify -}}
This assumes you have your light styles and dark mode styles stored in assets/syntax/light.css
and assets/syntax/dark.css
respectively.
Instead of doing the above, you could have just put both in a single file and include the @media (prefers-color-scheme: dark)
line in there directly, and this won't require you to change your <head>
at all. And of course you could have just used CSS variables and store the theme's colors into different variables, use var(--variable-name)
for each class in the styles, and finally have a different set up variable values for @media (prefers-color-scheme: dark) {}
. But using the method of separating dark and light styles has the advantage of changing the themes for light or dark mode in the future with the chroma
command and pipe it to the file directly, without having to edit the CSS file by hand.
Fetching syntax highlighting theme and putting it in your <head>
means that every single page would have the syntax highlighting CSS code in the page, regardless of whether the page actually uses it. If you'd like to only include the syntax CSS files for pages that needs syntax highlighting, you can use a page parameter named something like highlight
.
Here's how it would work.
highlight
param in your global config file that is set to false by default
content/
that needs syntax highlighting, include highlight: true
in the frontmatter (assuming you're using YAML).
<head>
, check whether the page's highlight
param is set to true, and only if it's true, the
CSS resource is loaded.
In your <head>
, include this before fetching the CSS resource, and put {{ end }}
after </style>
:
{{- if .Params.highlight -}} {{- end -}}
This tells hugo to only load the resource and put the CSS in <style>
if the page parameter highlight
is set to true.
There are many configuration options for syntax highlighting, read this page on Hugo docs for more information:
=> https://gohugo.io/getting-started/configuration-markup#highlight
If you'd like to highlight specific lines in code snippets, you can read about how to do that here:
=> https://gohugo.io/content-management/syntax-highlighting/#example-highlight-shortcode
There is also a highlight
shortcode shipped with Hugo that lets you manually highlight code with chroma: gohugo.io/content-management/shortcodes/#highlight:
=> https://gohugo.io/content-management/shortcodes/#highlight
tags: #howto, #hugo
=> ← Gemlog | ← Capsule home | Source | View this page on the web
Capsule last rebuilt on 2025-01-11
text/gemini
This content has been proxied by September (ba2dc).