26 KiB
+++ tags = ["Content"] title = "Markdown Syntax" weight = 4 +++
Let's face it: Writing content for the web is tiresome. WYSIWYG editors help alleviate this task, but they generally result in horrible code, or worse yet, ugly web pages.
Markdown is a better way to write HTML, without all the complexities and ugliness that usually accompanies it.
Some of the key benefits are:
- Markdown is simple to learn, with minimal extra characters so it's also quicker to write content.
- Less chance of errors when writing in Markdown.
- Produces valid HTML output.
- Keeps the content and the visual display separate, so you cannot mess up the look of your site.
- Write in any text editor or Markdown application you like.
- Markdown is a joy to use!
John Gruber, the author of Markdown, puts it like this:
The overriding design goal for Markdown’s formatting syntax is to make it as readable as possible. The idea is that a Markdown-formatted document should be publishable as-is, as plain text, without looking like it’s been marked up with tags or formatting instructions. While Markdown’s syntax has been influenced by several existing text-to-HTML filters, the single biggest source of inspiration for Markdown’s syntax is the format of plain text email. John Gruber
{{% notice tip %}} {{% icon bookmark %}} Bookmark this page for easy future reference! {{% /notice %}}
Standard and Extensions
If not otherwise noted, the showed examples adhere to the Commonmark standard. In addition the theme supports the following extensions that can be activated in your hugo.toml
or are built into the theme:
-
{{% badge color="darkgray" icon="fa-fw fab fa-github" %}}GFM{{% /badge %}} Extension on top of standard Markdown adhering to GitHub Flavored Markdown.
-
{{% badge color="#888cc4" icon="fa-fw fab fa-markdown" %}}PHP{{% /badge %}} Extension on top of standard Markdown adhering to PHP Markdown.
-
{{% badge color="darkorange" icon="lightbulb" %}}Pants{{% /badge %}} Extension by John Gruber adhering to SmartyPants.
-
{{% badge color="fuchsia" icon="fa-fw fab fa-hackerrank" %}}Hugo{{% /badge %}} Hugo Extra Extension supported by Hugo.
-
{{% badge color="#7dc903" icon="fa-fw fas fa-puzzle-piece" %}}Relearn{{% /badge %}} Extension specific to this theme.
-
{{% badge color="orangered" icon="fa-fw fas fa-code" %}}HTML{{% /badge %}} If the usage of HTML is allowed, the theme supports styling for further HTML elements.
Paragraphs
In Markdown your content usually spans the whole available document width. This is called a block. Blocks are always separated by whitespace to their adjacent blocks in the resulting document.
Any text not starting with a special sign is written as normal, plain text paragraph block and must be separated to its adjacent blocks by empty lines.
Lorem ipsum dolor sit amet, graecis denique ei vel, at duo primis mandamus.
Et legere ocurreret pri, animal tacimates complectitur ad cum. Cu eum inermis inimicus efficiendi. Labore officiis his ex, soluta officiis concludaturque ei qui, vide sensibus vim ad.
{{% notice style="secondary" icon="eye" title="Result" %}} Lorem ipsum dolor sit amet, graecis denique ei vel, at duo primis mandamus.
Et legere ocurreret pri, animal tacimates complectitur ad cum. Cu eum inermis inimicus efficiendi. Labore officiis his ex, soluta officiis concludaturque ei qui, vide sensibus vim ad. {{% /notice %}}
Headings
A good idea is to structure your content using headings and subheadings. HTML-headings from h1
through h6
are constructed with a #
for each level.
In Hugo you usually don't use h1
as this is generated by your theme and you should only have one such element in a document.
# h1 Heading
## h2 Heading
### h3 Heading
#### h4 Heading
##### h5 Heading
###### h6 Heading
{{% notice style="secondary" icon="eye" title="Result" %}}
h1 Heading
h2 Heading
h3 Heading
h4 Heading
h5 Heading
h6 Heading
{{% /notice %}}
Horizontal Rules
To further structure your content you can add horizontal rules. They create a "thematic break" between paragraph blocks. In Markdown, you can create it with three consecutive dashes ---
.
Lorem ipsum dolor sit amet, graecis denique ei vel, at duo primis mandamus.
---
Et legere ocurreret pri, animal tacimates complectitur ad cum. Cu eum inermis inimicus efficiendi. Labore officiis his ex, soluta officiis concludaturque ei qui, vide sensibus vim ad.
{{% notice style="secondary" icon="eye" title="Result" %}} Lorem ipsum dolor sit amet, graecis denique ei vel, at duo primis mandamus.
Et legere ocurreret pri, animal tacimates complectitur ad cum. Cu eum inermis inimicus efficiendi. Labore officiis his ex, soluta officiis concludaturque ei qui, vide sensibus vim ad. {{% /notice %}}
Text Markers
Bold
You can show importance of a snippet of text with a heavier font-weight by enclosing it with two asterisks **
.
I am rendered with **bold text**
{{% notice style="secondary" icon="eye" title="Result" %}} I am rendered with bold text {{% /notice %}}
Italics
You can emphasize a snippet of text with italics by enclosing it with underscores _
.
I am rendered with _italicized text_
{{% notice style="secondary" icon="eye" title="Result" %}} I am rendered with italicized text {{% /notice %}}
Marked Text
You can mark text in the predefined accent color of your stylesheet.
{{% badge color="fuchsia" icon="fa-fw fab fa-hackerrank" %}}Hugo{{% /badge %}} Since Hugo 0.126.0, you can activate this through the Hugo Extra Extension in your hugo.toml
==Parts== of this text ==are marked!==
{{% badge color="orangered" icon="fa-fw fas fa-code" %}}HTML{{% /badge %}} You can also use it by configuring Hugo for usage of HTML.
<mark>Parts</mark> of this text <mark>are marked!</mark>
{{% notice style="secondary" icon="eye" title="Result" %}} Parts of this text are marked! {{% /notice %}}
Inserted Text
You can mark text additions to existing text.
{{% badge color="fuchsia" icon="fa-fw fab fa-hackerrank" %}}Hugo{{% /badge %}} Since Hugo 0.126.0, you can activate this through the Hugo Extra Extension in your hugo.toml
The ++hot, new++ stuff
{{% badge color="orangered" icon="fa-fw fas fa-code" %}}HTML{{% /badge %}} You can also use it by configuring Hugo for usage of HTML.
The <ins>hot, new</ins> stuff
{{% notice style="secondary" icon="eye" title="Result" %}} The ++hot, new++ stuff {{% /notice %}}
Deleted Text
{{% badge color="darkgray" icon="fa-fw fab fa-github" %}}GFM{{% /badge %}} You can do strikethroughs by enclosing text with two tildes ~~
. See Hugo's documentation remarks if you want to use this together with the subscript syntax.
~~Strike through~~ this text
{{% notice style="secondary" icon="eye" title="Result" %}}
Strike through this text
{{% /notice %}}
Special Typesetting
Text Substitution
{{% badge color="darkorange" icon="lightbulb" %}}Pants{{% /badge %}} You can combine multiple punctuation characters to single typographic entities. This will only be applied to text outside of code blocks or inline code.
Double quotes `"` and single quotes `'` of enclosed text are replaced by **"double curly quotes"** and **'single curly quotes'**.
Double dashes `--` and triple dashes `---` are replaced by en-dash **--** and em-dash **---** entities.
Double arrows pointing left `<<` or right `>>` are replaced by arrow **<<** and **>>** entities.
Three consecutive dots `...` are replaced by an ellipsis **...** entity.
{{% notice style="secondary" icon="eye" title="Result" %}}
Double quotes "
and single quotes '
of enclosed text are replaced by "double curly quotes" and 'single curly quotes'.
Double dashes --
and triple dashes ---
are replaced by en-dash -- and em-dash --- entities.
Double arrows pointing left <<
or right >>
are replaced by arrow << and >> entities.
Three consecutive dots ...
are replaced by an ellipsis ... entity.
{{% /notice %}}
Subscript and Superscript
You can also use subscript and superscript text. For more complex stuff, you can use the math
shortcode.
{{% badge color="fuchsia" icon="fa-fw fab fa-hackerrank" %}}Hugo{{% /badge %}} Since Hugo 0.126.0, you can activate this through the Hugo Extra Extension in your hugo.toml
How many liters H~2~O fit into 1dm^3^?
{{% badge color="orangered" icon="fa-fw fas fa-code" %}}HTML{{% /badge %}} You can also use it by configuring Hugo for usage of HTML.
How many liters H<sub>2</sub>O fit into 1dm<sup>3</sup>?
{{% notice style="secondary" icon="eye" title="Result" %}}
How many liters H2O fit into 1dm^3^?
{{% /notice %}}
Keyboard Shortcuts
{{% badge color="orangered" icon="fa-fw fas fa-code" %}}HTML{{% /badge %}} You can use the <kbd>
element to style keyboard shortcuts.
Press <kbd>STRG</kbd> <kbd>ALT</kbd> <kbd>DEL</kbd> to end your shift early.
{{% notice style="secondary" icon="eye" title="Result" %}} Press STRG ALT DEL to end your shift early. {{% /notice %}}
Lists
Unordered
You can write a list of items in which the order of the items does not explicitly matter.
It is possible to nest lists by indenting an item for the next sublevel.
You may use any of -
, *
or +
to denote bullets for each list item but should not switch between those symbols inside one whole list.
- Lorem ipsum dolor sit amet
- Consectetur adipiscing elit
- Vestibulum laoreet porttitor sem
- Ac tristique libero volutpat at
- Nulla volutpat aliquam velit
- Phasellus iaculis neque
- Purus sodales ultricies
- Faucibus porta lacus fringilla vel
{{% notice style="secondary" icon="eye" title="Result" %}}
- Lorem ipsum dolor sit amet
- Consectetur adipiscing elit
- Vestibulum laoreet porttitor sem
- Ac tristique libero volutpat at
- Nulla volutpat aliquam velit
- Phasellus iaculis neque
- Purus sodales ultricies
- Faucibus porta lacus fringilla vel {{% /notice %}}
Ordered
You can create a list of items in which the order of items does explicitly matter.
It is possible to nest lists by indenting an item for the next sublevel.
Markdown will automatically number each of your items consecutively. This means, the order number you are providing is irrelevant.
1. Lorem ipsum dolor sit amet
3. Consectetur adipiscing elit
1. Integer molestie lorem at massa
7. Facilisis in pretium nisl aliquet
99. Nulla volutpat aliquam velit
1. Faucibus porta lacus fringilla vel
1. Aenean sit amet erat nunc
17. Eget porttitor lorem
{{% notice style="secondary" icon="eye" title="Result" %}}
- Lorem ipsum dolor sit amet
- Consectetur adipiscing elit
- Integer molestie lorem at massa
- Facilisis in pretium nisl aliquet
- Nulla volutpat aliquam velit
- Faucibus porta lacus fringilla vel
- Aenean sit amet erat nunc
- Eget porttitor lorem {{% /notice %}}
Tasks
{{% badge color="darkgray" icon="fa-fw fab fa-github" %}}GFM{{% /badge %}} You can add task lists resulting in checked or unchecked non-clickable items
- [x] Basic Test
- [ ] More Tests
- [x] View
- [x] Hear
- [ ] Smell
{{% notice style="secondary" icon="eye" title="Result" %}}
- Basic Test
- More Tests
- View
- Hear
- Smell {{% /notice %}}
Definitions
{{% badge color="#888cc4" icon="fa-fw fab fa-markdown" %}}PHP{{% /badge %}} Definition lists are made of terms and definitions of these terms, much like in a dictionary.
A definition list in Markdown Extra is made of a single-line term followed by a colon and the definition for that term. You can also associate more than one term to a definition.
If you add empty lines around the definition terms, additional vertical space will be generated. Also multiple paragraphs are possible
Apple
: Pomaceous fruit of plants of the genus Malus in the family Rosaceae.
: An American computer company.
Orange
: The fruit of an evergreen tree of the genus Citrus.
You can make juice out of it.
: A telecommunication company.
You can't make juice out of it.
- {{% notice style="secondary" icon="eye" title="Result" %}}
- Apple
- Pomaceous fruit of plants of the genus Malus in the family Rosaceae.
- An American computer company.
- Orange
- The fruit of an evergreen tree of the genus Citrus.
You can make juice out of it.
- A telecommunication company.
You can't make juice out of it. {{% /notice %}}
Code
Inline Code
Inline snippets of code can be wrapped with backticks `
.
In this example, `<div></div>` is marked as code.
{{% notice style="secondary" icon="eye" title="Result" %}}
In this example, <div></div>
is marked as code.
{{% /notice %}}
Indented Code Block
A simple code block can be generated by indenting several lines of code by at least two spaces.
Be impressed by my advanced code:
// Some comments
line 1 of code
line 2 of code
line 3 of code
{{% notice style="secondary" icon="eye" title="Result" %}} Be impressed by my advanced code:
// Some comments
line 1 of code
line 2 of code
line 3 of code
{{% /notice %}}
Fenced Code Block
If you want to gain more control of your code block you can enclose your code by at least three backticks ```
a so called fence.
{{% badge color="darkgray" icon="fa-fw fab fa-github" %}}GFM{{% /badge %}} You can also add a language specifier directly after the opening fence, ```js
, and syntax highlighting will automatically be applied according to the selected language in the rendered HTML.
See Code Highlighting for additional documentation.
```js
{
name: "Claus",
surname: "Santa",
profession: "courier",
age: 666,
address: {
city: "North Pole",
postalCode: 1,
country: "Arctic"
},
friends: [ "Dasher", "Dancer", "Prancer", "Vixen", "Comet", "Cupid", "Donder", "Blitzen", "Rudolph" ]
};
```
{{% notice style="secondary" icon="eye" title="Result" %}}
{
name: "Claus",
surname: "Santa",
profession: "courier",
age: 666,
address: {
city: "North Pole",
postalCode: 1,
country: "Arctic"
},
friends: [ "Dasher", "Dancer", "Prancer", "Vixen", "Comet", "Cupid", "Donder", "Blitzen", "Rudolph" ]
};
{{% /notice %}}
Tables
{{% badge color="darkgray" icon="fa-fw fab fa-github" %}}GFM{{% /badge %}} You can create tables by adding pipes as dividers between each cell, and by adding a line of dashes (also separated by bars) beneath the header. Note that the pipes do not need to be vertically aligned.
| Option | Description |
|--------|-------------|
| data | path to data files to supply the data that will be passed into templates. |
| engine | engine to be used for processing templates. Handlebars is the default. |
| ext | extension to be used for dest files. |
{{% notice style="secondary" icon="eye" title="Result" %}}
Option | Description |
---|---|
data | path to data files to supply the data that will be passed into templates. |
engine | engine to be used for processing templates. Handlebars is the default. |
ext | extension to be used for dest files. |
{{% /notice %}} |
Aligned Columns
Adding a colon on the left and/or right side of the dashes below any heading will align the text for that column accordingly.
| Option | Number | Description |
|-------:|:------:|:------------|
| data | 1 | path to data files to supply the data that will be passed into templates. |
| engine | 2 | engine to be used for processing templates. Handlebars is the default. |
| ext | 3 | extension to be used for dest files. |
{{% notice style="secondary" icon="eye" title="Result" %}}
Option | Number | Description |
---|---|---|
data | 1 | path to data files to supply the data that will be passed into templates. |
engine | 2 | engine to be used for processing templates. Handlebars is the default. |
ext | 3 | extension to be used for dest files. |
{{% /notice %}} |
Blockquotes
For quoting blocks of content from another source within your document add >
before any text you want to quote.
Blockquotes can also be nested.
> Donec massa lacus, ultricies a ullamcorper in, fermentum sed augue. Nunc augue, aliquam non hendrerit ac, commodo vel nisi.
>
> > Sed adipiscing elit vitae augue consectetur a gravida nunc vehicula. Donec auctor odio non est accumsan facilisis. Aliquam id turpis in dolor tincidunt mollis ac eu diam.
>
> Mauris sit amet ligula egestas, feugiat metus tincidunt, luctus libero. Donec congue finibus tempor. Vestibulum aliquet sollicitudin erat, ut aliquet purus posuere luctus.
{{% notice style="secondary" icon="eye" title="Result" %}}
Donec massa lacus, ultricies a ullamcorper in, fermentum sed augue. Nunc augue, aliquam non hendrerit ac, commodo vel nisi.
Sed adipiscing elit vitae augue consectetur a gravida nunc vehicula. Donec auctor odio non est accumsan facilisis. Aliquam id turpis in dolor tincidunt mollis ac eu diam.
Mauris sit amet ligula egestas, feugiat metus tincidunt, luctus libero. Donec congue finibus tempor. Vestibulum aliquet sollicitudin erat, ut aliquet purus posuere luctus. {{% /notice %}}
Links
Autolink
{{% badge color="darkgray" icon="fa-fw fab fa-github" %}}GFM{{% /badge %}} Absolute URLs will automatically be converted into a link.
This is a link to https://example.com.
{{% notice style="secondary" icon="eye" title="Result" %}} This is a link to https://example.com. {{% /notice %}}
Basic Link
You can explicitly define links in case you want to use non-absolute URLs or want to give different text.
[Assemble](http://assemble.io)
{{% notice style="secondary" icon="eye" title="Result" %}} Assemble {{% /notice %}}
Link with Tooltip
For even further information, you can add an additional text, displayed in a tooltip on hovering over the link.
[Upstage](https://github.com/upstage/ "Visit Upstage!")
{{% notice style="secondary" icon="eye" title="Result" %}} Upstage {{% /notice %}}
Link References
Links can be simplyfied for recurring reuse by using a reference ID to later define the URL location. This simplyfies writing if you want to use a link more than once in a document.
[Example][somelinkID]
[somelinkID]: https://example.com "Go to example domain"
{{% notice style="secondary" icon="eye" title="Result" %}} Example
{{% /notice %}}
Footnotes
{{% badge color="#888cc4" icon="fa-fw fab fa-markdown" %}}PHP{{% /badge %}} Footnotes work mostly like reference-style links. A footnote is made of two things, a marker in the text that will become a superscript number and a footnote definition that will be placed in a list of footnotes.
Usually the list of footnotes will be shown at the end of your document. If we use a footnote in a notice box it will instead be listed at the end of its box.
Footnotes can contain block elements, which means that you can put multiple paragraphs, lists, blockquotes and so on in a footnote. It works the same as for list items, just indent the following paragraphs by four spaces in the footnote definition.
That's some text with a footnote[^1]
[^1]: And that's the footnote.
That's some more text with a footnote.[^someid]
[^someid]:
Anything of interest goes here.
Blue light glows blue.
{{% notice style="secondary" icon="eye" title="Result" %}} That's some text with a footnote1
That's some more text with a footnote.2
Images
Basic Images
Images have a similar syntax to links but include a preceding exclamation mark.
![Spock](https://octodex.github.com/images/spocktocat.png)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
Image with Tooltip
Like links, images can also be given a tooltip.
![Picard](https://octodex.github.com/images/jean-luc-picat.jpg "Jean Luc Picard")
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
Image References
Images can also be linked by reference ID to later define the URL location. This simplyfies writing if you want to use an image more than once in a document.
![La Forge][laforge]
[laforge]: https://octodex.github.com/images/trekkie.jpg "Geordi La Forge"
{{% notice style="secondary" icon="eye" title="Result" %}}
{{% /notice %}}
Image Effects
{{% badge color="#7dc903" icon="fa-fw fas fa-puzzle-piece" %}}Relearn{{% /badge %}} This theme allows additional non-standard formatting by setting query parameter at the end of the image URL. The default behavior is configurable through your hugo.toml
or frontmatter parameter.
Resizing
Add query parameter width
and/or height
to the link image to resize the image. Values are CSS values (default is auto
).
![Minion](https://octodex.github.com/images/minion.png?width=20vw)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
![Minion](https://octodex.github.com/images/minion.png?height=50px)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
![Minion](https://octodex.github.com/images/minion.png?height=50px&width=40vw)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
CSS Classes
Add a query parameter classes
to the link image to add CSS classes. Add some of the predefined values or even define your own in your CSS.
Shadow
![Spidertocat](https://octodex.github.com/images/spidertocat.png?classes=shadow)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
Border
![DrOctocat](https://octodex.github.com/images/droctocat.png?classes=border)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
Left
![Supertocat](https://octodex.github.com/images/okal-eltocat.jpg?classes=left)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
Right
![Riddlocat](https://octodex.github.com/images/riddlocat.jpg?classes=right)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
Inline
![Spidertocat](https://octodex.github.com/images/spidertocat.png?classes=inline)
![DrOctocat](https://octodex.github.com/images/droctocat.png?classes=inline)
![Supertocat](https://octodex.github.com/images/okal-eltocat.jpg?classes=inline)
![Riddlocat](https://octodex.github.com/images/riddlocat.jpg?classes=inline)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
Combination
![X-tocat](https://octodex.github.com/images/xtocat.jpg?classes=shadow,border,left)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
Lightbox
Add the query parameter lightbox=false
to the image link to disable the lightbox.
![Homercat](https://octodex.github.com/images/homercat.png?lightbox=false)
{{% notice style="secondary" icon="eye" title="Result" %}} {{% /notice %}}
{{% notice note %}}
If you want to wrap an image in a link and lightbox=true
is your default setting, you have to explicitly disable the lightbox to avoid it to hijacking your link like:
[![Homercat](https://octodex.github.com/images/homercat.png?lightbox=false)](https://octodex.github.com/#homercat)
{{% /notice %}}