Skip to content

Latest commit

 

History

History
169 lines (147 loc) · 4.15 KB

2012-07-01-frontmatter.md

File metadata and controls

169 lines (147 loc) · 4.15 KB
layout title prev_section next_section
docs
Front-matter
configuration
posts

The front-matter is where Jekyll starts to get really cool. Any file that contains a YAML front matter block will be processed by Jekyll as a special file. The front matter must be the first thing in the file and must take the form of valid YAML set between triple-dashed lines. Here is a basic example:

{% highlight yaml %}

layout: post title: Blogging Like a Hacker

{% endhighlight %}

Between these triple-dashed lines, you can set predefined variables (see below for a reference) or even create custom ones of your own. These variables will then be available to you to access using Liquid tags both further down in the file and also in any layouts or includes that the page or post in question relies on.

UTF-8 Character Encoding Warning

If you use UTF-8 encoding, make sure that no BOM header characters exist in your files or very, very bad things will happen to Jekyll. This is especially relevant if you’re running Jekyll on Windows.

Predefined Global Variables

There are a number of predefined global variables that you can set in the front-matter of a page or post.

Variable Description

layout

      If set, this specifies the layout file to use. Use the layout file
      name without the file extension. Layout files must be placed in the
      <code>_layouts</code> directory.

    </p>
  </td>
</tr>
<tr>
  <td>
    <p><code>permalink</code></p>
  </td>
  <td>
    <p>

      If you need your processed blog post URLs to be something other than
      the default <code>/year/month/day/title.html</code> then you can set
      this variable and it will be used as the final URL.

    </p>
  </td>
</tr>
<tr>
  <td>
    <p><code>published</code></p>
  </td>
  <td>
    <p>
      Set to false if you don’t want a specific post to show up when the
      site is generated.
    </p>
  </td>
</tr>
<tr>
  <td>
    <p style="margin-bottom: 5px;"><code>category</code></p>
    <p><code>categories</code></p>
  </td>
  <td>
    <p>

      Instead of placing posts inside of folders, you can specify one or
      more categories that the post belongs to. When the site is generated
      the post will act as though it had been set with these categories
      normally. Categories (plural key) can be specified as a <a
      href="http://en.wikipedia.org/wiki/YAML#Lists">YAML list</a> or a
      space-separated string.

    </p>
  </td>
</tr>
<tr>
  <td>
    <p><code>tags</code></p>
  </td>
  <td>
    <p>

      Similar to categories, one or multiple tags can be added to a post.
      Also like categories, tags can be specified as a YAML list or a space-
      separated string.

    </p>
  </td>
</tr>

Custom Variables

Any variables in the front matter that are not predefined are mixed into the data that is sent to the Liquid templating engine during the conversion. For instance, if you set a title, you can use that in your layout to set the page title:

{% highlight html %}

<title>{% raw %}{{ page.title }}{% endraw %}</title> ... {% endhighlight %}

Predefined Variables for Posts

These are available out-of-the-box to be used in the front-matter for a post.

Variable Description

date

A date here overrides the date from the name of the post. This can be used to ensure correct sorting of posts.