2021-12-18 11:08:58 +08:00
# Markdown
2021-12-20 12:26:37 +08:00
mdBook's [parser ](https://github.com/raphlinus/pulldown-cmark ) adheres to the [CommonMark ](https://commonmark.org/ ) specification with some extensions described below.
You can take a quick [tutorial ](https://commonmark.org/help/tutorial/ ),
2021-12-18 11:08:58 +08:00
or [try out ](https://spec.commonmark.org/dingus/ ) CommonMark in real time. A complete Markdown overview is out of scope for
this documentation, but below is a high level overview of some of the basics. For a more in-depth experience, check out the
[Markdown Guide ](https://www.markdownguide.org ).
## Text and Paragraphs
2021-12-19 07:50:51 +08:00
Text is rendered relatively predictably:
```markdown
Here is a line of text.
This is a new line.
```
Will look like you might expect:
Here is a line of text.
This is a new line.
## Headings
Headings use the `#` marker and should be on a line by themselves. More `#` mean smaller headings:
```markdown
### A heading
Some text.
#### A smaller heading
More text.
```
### A heading
Some text.
#### A smaller heading
More text.
## Lists
Lists can be unordered or ordered. Ordered lists will order automatically:
```markdown
* milk
* eggs
* butter
1. carrots
1. celery
1. radishes
```
* milk
* eggs
* butter
1. carrots
1. celery
1. radishes
2021-12-18 11:08:58 +08:00
## Links
2021-12-19 08:00:46 +08:00
Linking to a URL or local file is easy:
```markdown
Use [mdBook ](https://github.com/rust-lang/mdBook ).
Read about [mdBook ](mdBook.md ).
A bare url: < https: / / www . rust-lang . org > .
```
Use [mdBook ](https://github.com/rust-lang/mdBook ).
Read about [mdBook ](mdBook.md ).
A bare url: < https: / / www . rust-lang . org > .
2021-12-20 12:26:37 +08:00
----
Relative links that end with `.md` will be converted to the `.html` extension.
It is recommended to use `.md` links when possible.
This is useful when viewing the Markdown file outside of mdBook, for example on GitHub or GitLab which render Markdown automatically.
Links to `README.md` will be converted to `index.html` .
This is done since some services like GitHub render README files automatically, but web servers typically expect the root file to be called `index.html` .
You can link to individual headings with `#` fragments.
For example, `mdbook.md#text-and-paragraphs` would link to the [Text and Paragraphs ](#text-and-paragraphs ) section above.
The ID is created by transforming the heading such as converting to lowercase and replacing spaces with dashes.
You can click on any heading and look at the URL in your browser to see what the fragment looks like.
2021-12-18 11:08:58 +08:00
## Images
Including images is simply a matter of including a link to them, much like in the _Links_ section above. The following markdown
includes the Rust logo SVG image found in the `images` directory at the same level as this file:
```markdown
![The Rust Logo ](images/rust-logo-blk.svg )
```
Produces the following HTML when built with mdBook:
```html
< p > < img src = "images/rust-logo-blk.svg" alt = "The Rust Logo" / > < / p >
```
Which, of course displays the image like so:
![The Rust Logo ](images/rust-logo-blk.svg )
2021-12-20 12:26:37 +08:00
## Extensions
mdBook has several extensions beyond the standard CommonMark specification.
### Strikethrough
Text may be rendered with a horizontal line through the center by wrapping the
text with two tilde characters on each side:
```text
An example of ~~strikethrough text~~ .
```
This example will render as:
> An example of ~~strikethrough text~~.
This follows the [GitHub Strikethrough extension][strikethrough].
### Footnotes
A footnote generates a small numbered link in the text which when clicked
takes the reader to the footnote text at the bottom of the item. The footnote
label is written similarly to a link reference with a caret at the front. The
footnote text is written like a link reference definition, with the text
following the label. Example:
```text
This is an example of a footnote[^note].
[^note]: This text is the contents of the footnote, which will be rendered
towards the bottom.
```
This example will render as:
> This is an example of a footnote[^note].
>
> [^note]: This text is the contents of the footnote, which will be rendered
> towards the bottom.
The footnotes are automatically numbered based on the order the footnotes are
written.
### Tables
Tables can be written using pipes and dashes to draw the rows and columns of
the table. These will be translated to HTML table matching the shape. Example:
```text
| Header1 | Header2 |
|---------|---------|
| abc | def |
```
This example will render similarly to this:
| Header1 | Header2 |
|---------|---------|
| abc | def |
See the specification for the [GitHub Tables extension][tables] for more
details on the exact syntax supported.
### Task lists
Task lists can be used as a checklist of items that have been completed.
Example:
```md
- [x] Complete task
- [ ] Incomplete task
```
This will render as:
> - [x] Complete task
> - [ ] Incomplete task
See the specification for the [task list extension] for more details.
### Smart punctuation
Some ASCII punctuation sequences will be automatically turned into fancy Unicode
characters:
| ASCII sequence | Unicode |
|----------------|---------|
| `--` | – |
| `---` | — |
| `...` | … |
| `"` | “ or ”, depending on context |
| `'` | ‘ or ’ , depending on context |
So, no need to manually enter those Unicode characters!
This feature is disabled by default.
To enable it, see the [`output.html.curly-quotes`] config option.
2021-12-19 08:00:46 +08:00
2021-12-20 12:26:37 +08:00
[strikethrough]: https://github.github.com/gfm/#strikethrough-extension-
[tables]: https://github.github.com/gfm/#tables-extension-
[task list extension]: https://github.github.com/gfm/#task-list-items-extension-
[`output.html.curly-quotes`]: configuration/renderers.md#html-renderer-options