title | nav |
---|---|
5-Ref |
true |
The basic components of the Jekyll stack are described below.
Markdown{:target="_blank" rel="noopener"} is a standard to simplify writing content for the web. GitHub markdown flavor{:target="_blank" rel="noopener"} can be used any where on GitHub and in Jekyll. The basics are intuitive, you can learn in about a minute{:target="_blank" rel="noopener"}!
Check out this GitHub Markdown tutorial{:target="_blank" rel="noopener"} for more info.
Note: Jekyll uses the Ruby based kramdown{:target="_blank" rel="noopener"} to compile Markdown, so supports a few extras beyond the standard syntax. Check the kramdown quickref{:target="_blank" rel="noopener"}.
This Markdown code:
## Heading two
### Heading three, etc.
Any text with no empty lines between will become a paragraph.
Font can be *Italic* or **Bold**.
Code can be highlighted with `backticks`.
Links look like this [GitHub Help](https://help.github.com/).
List:
- dog
- cat
Numbered:
1. one
2. two
> Block quote.
-------
Will be rendered like this:
Any text with no empty lines between will become a paragraph.
Font can be Italic or Bold.
Code can be highlighted with backticks
.
Links look like this GitHub Help.
List:
- dog
- cat
Numbered:
- one
- two
Block quote.
YAML{:target="_blank" rel="noopener"} is a human readable plain text data format. It is used in Jekyll for configuration, site data, and front matter:
- Jekyll projects are configured{:target="_blank" rel="noopener"} using the
_config.yml
file. - YAML, JSON, or CSV files in the
_data
directory are exposed by Jekyll as site data{:target="_blank" rel="noopener"} for Liquid templating. - Any file in a Jekyll project with YAML Front matter{:target="_blank" rel="noopener"} will be processed, others are just directly copied the the
_site
directory on build. For example, the front matter for the markdown file generating this page looks like:
---
layout: default
title: 5-Ref
---
Liquid{:target="_blank" rel="noopener"} is a flexible template language.
In Jekyll{:target="_blank" rel="noopener"} it allows you to layout pages built from modular components and data, using the _includes
, _layouts
, and _data
directories.
Liquid includes features such as operators, loops, and filters to manipulate raw content.
Liquid statements are enclosed by {% raw %}{% %}
{% endraw %} and variables in {% raw %}{{ }}
{% endraw %}.
For example, the default
layout used for this page looks like:
{% raw %}
<!DOCTYPE html>
<html lang="en">
{% include head.html %}
<body>
{% include header.html %}
<main class="page-content" aria-label="Content">
<div class="wrapper">
{{ content }}
</div>
</main>
{% include footer.html %}
</body>
</html>
{% endraw %}
Sass{:target="_blank" rel="noopener"} is a CSS extension / preprocessor.
All normal CSS is valid SCSS, but Sass adds many powerful functions and programatic features.
Writing SCSS is often easier and more sensible, for example by supporting nesting, variables, and operators.
Jekyll lets you write SASS in modular chucks called partials, in the _sass
directory, that will be combined and compiled into normal CSS files when the site is built.
For example, notice the variables, nesting, and operators in the SCSS below:
$base-font-family: Helvetica, sans-serif;
$base-font-size: 16px;
$primary-color: #333;
$padding-links: 6px 12px;
nav {
font-family: $base-font-family;
font-size: $base-font-size * 1.25;
color: lighten($primary-color, 25%);
ul {
list-style: none;
}
li { display: inline-block; }
a {
padding: $padding-links;
text-decoration: none;
}
}
@import "base";
Jekyll themes{:target="_blank" rel="noopener"} are really just a skeleton of directories and files making up a project. Some are Gems and can be installed by adding the theme to the config and gem file, which case you will not see the theme directories in your project. Others should just be downloaded and added to your project directory manually.
- Search for Jekyll themes, there are lots of directories: Gem based{:target="_blank" rel="noopener"}, "Jekyll Themes"{:target="_blank" rel="noopener"}, and another "Jekyll Themes"{:target="_blank" rel="noopener"}
- Themes supported by gh-pages{:target="_blank" rel="noopener"}, these can be added to
_config.yml
as in [3-Jekyll]({{ "/3-jekyll.html" | absolute_url }}) example and are the same as the Theme Chooser options. Onlyminima
has navigation, alternative layouts, or blog post support built in--so they are not very useful. However, looking at the repository will give you info about how to customize the themes. - Remote themes on GitHub{:target="_blank" rel="noopener"}, any theme that is hosted on GitHub can be used by adding
remote_theme: owner/name
to_config.yml
. You can find options in the jekyll-theme topic{:target="_blank" rel="noopener"}.
If you are developing for gh-pages, it is a good idea to keep your environment in sync with what is used on GitHub.
This can be done automatically using the github-pages gem{:target="_blank" rel="noopener"} (although I rarely bother to do so).
To see what version of Jekyll and which plugins GH-Pages use, take a look at the Dependency Versions page{:target="_blank" rel="noopener"}.
Most of these are builtin dependencies of Jekyll, but there are a few plugins of interest.
To use the extra plugins, add them to your _config.yml
, under gems:
, not in the the gemfile (since gh-pages ignores that).
- jekyll-seo-tag (GitHub info{:target="_blank" rel="noopener"}, usage{:target="_blank" rel="noopener"}, basically add {% raw %}
{% seo %}
{% endraw %} to the<head>
of your pages, and make sure you have all the metadata in your_config.yml
). - jekyll-sitemap (GitHub info{:target="_blank" rel="noopener"}, repo{:target="_blank" rel="noopener"}).