Static Site Generator

Last edited: January 6, 2025 - 4 minutes read

Description

How to create your own hugo website and theme.

Content

Hugo is a static site generator. It is used to create website content using markdown instead of having to write html. You can read more about hugo on it’s website.

If you are curious about how hugo was used in the implementation of this website you can also check out my github repository.

1. Creating the website

After you have installed hugo through your package manager of choice, you can create a new hugo site by running in your terminal:

$ hugo new site my-website

This will create a my-website directory with the following hierarchy:

.
├── archetypes
│   └── default.md
├── config.toml
├── content
├── data
├── layouts
├── public
├── static
└── themes

The most important directories here are content/, which stores your website’s content as markdown files, and static/ which stores any other assets you wish to have on your website, such as images or files.

2. Creating a theme

Change directory into my-website/ and run:

$ hugo new theme my-theme

This will create a my-theme/ directory inside themes/ with the following hierarchy:

.
├── LICENSE
├── archetypes
│   └── default.md
├── layouts
│   ├── 404.html
│   ├── _default
│   │   ├── baseof.html
│   │   ├── list.html
│   │   └── single.html
│   ├── index.html
│   └── partials
│       ├── footer.html
│       ├── head.html
│       └── header.html
├── static
│   ├── css
│   └── js
└── theme.toml

The theme controls exactly how your website will look and function. Your content will be transformed into html based on the rules you define here.

In hugo, there are two main types of pages:

  • Lists
  • Singles

which are created depending on the structure of your content/ directory. Let’s imagine a directory structure like:

.
├── about.md
└── post
    ├── 1st-post.md
    ├── 2nd-post.md
    └── 3rd-post.md

Here about.md, and each of the posts inside post/ are all single pages. post/ itself is a list. We can control how these pages are displayed by editing the files single.html and list.html inside layouts/_default/. Let’s do so.

Edit single.html so that the content is as follows:

{{ define "main" }}
<div>{{ .Content }}</div>
{{ end }}

and list.html like so:

{{ define "main" }}
<ul>
  {{ range.Pages }}
  <li><a href="{{ .RelPermalink }}">{{ .Title }}</a></li>
  {{ end }}
</ul>
{{ end }}

List pages will now show an unordered list with links to their single pages, and single pages will show their respective content.

Finally lets edit index.html inside layout/ in order to customize our main page.

<a href="/about">about</a> <a href="/post">posts</a>

3. Configuring the website

We are done with our simple theme. Now we need to edit our config.toml file in order to use the theme we have just created. Change directory back into my-website/ and run:

$ echo "theme = 'my-theme'" >> config.toml

4. Adding content

You now have a fully functional hugo website and are ready to start posting content. Let’s write the about page and a helloworld post.

$ hugo new about.md
$ hugo new post/helloworld.md

This will create a about.md file inside content/ and a helloworld.md file inside content/post/. Both files will have content similar to this:

---
title: "About"
date: 2022-07-22T14:24:31+01:00
draft: true
---

Let’s add some markdown to both.

Edit about.md:

---
title: "About"
date: 2022-07-22T14:24:31+01:00
draft: true
---

This is the about page.

Edit helloworld.md:

---
title: "Helloworld"
date: 2022-07-22T14:24:31+01:00
draft: true
---

# Helloworld

this is an example.

5. Live preview

We are now ready to see the results using a local server provided by hugo. Run:

$ hugo server -D

where the -D option is used so drafts are also shown.

A server will be started (likely on localhost:1313). Here is the result:

Homepage of the website. configured in layouts/index.html.

localhost:1313/

Homepage of the website. configured in layouts/index.html.

Single page. configured in layouts/_default/single.html with content from content/about.md.

localhost:1313/about

Single page. configured in layouts/_default/single.html with content from content/about.md.

List page. configured in layouts/_default/list.html and lists single pages within content/post/.

localhost:1313/post

List page. configured in layouts/_default/list.html and lists single pages within content/post/.

Another example of a single page. Content from content/post/helloworld.md.

localhost:1313/post/helloword

Another example of a single page. Content from content/post/helloworld.md.

At this point you can continue editing the all the files mentioned to your liking. Everytime you save your changes the website will automatically reload.

6. Publishing the website

Once you’re satisfied with your changes, you can generate the static website by running:

$ hugo

This will output all the static files you need into public/.

PostsNext >