Building a blog using Jekyll. Creating custom layouts

Using the versatility of Liquid language, you can practically build any layout you want in Jekyll. Here's a quick explanation on how to do it.

This post assumes that you have a basic knowledge of the folder structure of a Jekyll project and basic Liquid syntax. If you don't you can go to my previous post where I explain this.

Jekyll comes with a handy new command that creates a boilerplate site you can start with. Though it's great to start playing around, and I suggest you do, I prefer to start from zero ground to feel sure that there isn't something there I would have never chosen to put.

If you're going my way and you're starting with an empty folder then you're going to need a _config.yml file or the build and serve commands won't work. You can start with this sample.

# site settings
title: Your awesome title
author: Your name
description: 'Write an awesome description for your new site here.'

# build settings
port: 4000
highlighter: pygments
markdown: redcarpet
permalink: pretty

Some of the values here are default like the port, but the default the markdown engine is karmdown. My choice is redcarpet.

Except for the build settings, the rest of the properties you declare here are going to be available in your layouts under the site namespace.

Modularize your pages

The first thing that you need to do is separate parts that are going to be in every section, or at least in more than one, in your site. Then you put does small HTML parts inside the _includes folder.

The most common parts are the head tag, the header and the footer of your site, but this depends on the design you're trying to achieve. You can have a side column, a recent posts section you can attach to every article or a badge with your information for example.

Includes make maintainance much easier, something similar to what you have in php based generators

Doing this will make maintainance much easier, something similar to what you have in php based generators like Wordpress. This time, they are just .html files and the only thing you're required to do is to include this parts inside the _includes folder and nothing more.

You can still play a little with Liquid here. For example inside the head tag you can check if the page has a title, and if not you can default to the site title.

<head>
  <meta charset="utf-8" />
  <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  <title>
    {% if page.title %} {{ page.title }} {% else %} {{ site.title }} {%
    endif %}
  </title>
  <meta
    name="description"
    content="{{ site.description }}"
  />
  <meta name="viewport" content="width=device-width" />
</head>

We save this as head.html inside the _includes folder and we can now create more versatile base templates.

_layouts

This is the name of your folder where your layouts, pretty obvious, are going to be placed. There's not much to explain here, the best is to show you how a layout would look in Jekyll.

<!doctype html>
<html lang="en">
  {% include head.html %} {% include header.html
  %}

  <body>
    <div class="page-wrapper">{{ content }}</div>
  </body>

  {% include footer.html %}
</html>

Pretty easy to understand. We're going to call this layout default.html, but if we want more special layouts for pages or posts we can add as many as we want. For example, let's create a post layout structure. This time the {{ content }} placeholder will hold the text inside the article and not the whole page.

<!doctype html>
<html lang="en">
  {% include head.html %} {% include header.html
  %}

  <body>
    <div class="post-wrapper">
      <p class="post-date">{{ page.date }}</p>
    </div>
    <h1 class="post-title"></h1>
    <div class="post-content">{{ content }}</div>
  </body>

  {% include footer.html %}
</html>

With small changes you can heavily alter the markup and structure of your templates, and the more you know Liquid blocks and built in filters the more powerful these layouts can become.

Create your index page

Now that we have the basic needs for our site, we can create an index file in our folder. This file can either be an html file or a markdown file.

---
layout: default
---

## Hi, welcome to my site!

This is the **index** page. This site is built with Jekyll.

After you've saved this file in the root folder, you can run the serve command and see the results.

You might have noticed that before starting with the content we specify the layout that Jekyll needs to use to render this page as a configuration property. You can also put other variables like a title or excerpt and they can be accessed through the page namespace as we did in our head.html file above.

Wrap-up

Placing html files in some specific folders and with some basic Liquid blocks we're able to build infinite template flavors. This is why Jekyll is so powerful, it relies on simple languages and technologies.

I hope you found this article useful, if not you can always go to Jekyll's official documentation.

Do you want me to speak at your conference or write for your publication?

Click here to contact me for collaborations.