Markdown扩展语法 #
概述 #
原始 Markdown 设计文档中概述的 基本语法添加了许多日常所需的元素,但对于某些人来说这还不够。这就是扩展语法的用武之地。
一些个人和组织通过添加其他元素(如表格、代码块、语法高亮、URL 自动链接和脚注)来扩展 基本语法。可以通过使用基于 基本Markdown语法构建的轻量级标记语言,或者通过向兼容的 Markdown 处理器添加扩展来启用这些元素。
可用性 #
并非所有 Markdown 应用程序都支持扩展语法元素。您需要检查您的应用程序使用的轻量级标记语言是否支持您要使用的扩展语法元素。如果没有,则仍可以在 Markdown 处理器中启用扩展。
轻量级标记语言 #
有几种轻量级标记语言是 Markdown 的超集。它们包括基本语法,并通过添加其他元素(如表格、代码块、语法高亮、URL 自动链接和脚注)来构建它。许多最流行的 Markdown 应用程序使用以下轻量级标记语言之一:
Markdown处理器 #
有数十种 Markdown处理器可用。其中许多允许您添加启用扩展语法元素的扩展。有关更多信息,请查看您的处理器的文档。
表格 #
要添加表格,请使用三个或更多连字符 (—) 创建每列的标题,并使用竖线 (|) 分隔每列。为了兼容性,您还应该在行的任一端添加一个管道。
| 语法 | 描述 |
| ----------- | ----------- |
| Header | 标题 |
| Paragraph | 文本 |
渲染输出结果如下:
语法 | 描述 |
---|---|
Header | Title |
Paragraph | Text |
单元格宽度可能会有所不同,如下所示。但渲染输出得结果显示确实一样的。
| 语法 | 描述 |
| --- | ----------- |
| Header | Title |
| Paragraph | Text |
提示: 使用连字符和竖线创建表格可能很乏味。为了加快这个过程,请尝试使用[Markdown Tables Generator](www.tablesgenerator.com/markdown_tables)或[AnyWayData Markdown Export](https://anywaydata.com)。使用图形界面构建表格,然后将生成的 Markdown 格式文本复制到您的文件中。
对齐方式 #
您可以通过在标题行内连字符的左侧、右侧或两侧添加冒号 (:) 来将列中的文本向左、向右或居中对齐。
| 语法 | 描述 | 测试文本 |
| :--- | :----: | ---: |
| Header | Title | Here's this |
| Paragraph | Text | And more |
渲染输出结果如下:
语法 | 描述 | 测试文本 |
---|---|---|
Header | Title | Here’s this |
Paragraph | Text | And more |
表格中文本格式 #
您可以设置表格中文本的格式。例如,您可以添加 链接、 代码(仅支持反引号而不是 代码块)和 强调。
您不能使用标题、块引用、列表、水平线、图像或大多数 HTML 标签。
提示:您可以使用 HTML 创建[换行符](../hacks/#line-breaks-within-table-cells)并在表格单元格中添加[列表](../hacks/#lists-within-table-cells)。
在表中转义竖线字符 #
您可以使用表格的 HTML 字符代码 (|
) 在表格中显示竖线 (|) 字符。
围栏代码块 #
基本的 Markdown 语法允许您通过用四个空格或 1 个制表符缩进行来创建 代码块。如果你觉得这不方便,可以尝试使用围栏代码块。根据你的 Markdown 处理器或编辑器,你将在代码块前后的行上使用三个反引号 (’’’) 或三个波浪号 (~~~)。这样做的好处是不必缩进任何行。
```
{
"firstName": "John",
"lastName": "Smith",
"age": 25
}
```
渲染输出结果如下:
{
"firstName": "John",
"lastName": "Smith",
"age": 25
}
提示: 需要在代码块内显示反引号请参阅[转义反引号](../basic-syntax/#转义反引号)以了解如何转义它们。
语法高亮显示 #
许多 Markdown 处理器支持围栏代码块的语法高亮显示。此功能允许您为编写代码的任何语言添加颜色突出显示。要添加语法高亮显示,请在围栏代码块前面的反引号旁边指定一种语言。
```json
{
"firstName": "John",
"lastName": "Smith",
"age": 25
}
```
渲染输出结果如下:
{
"firstName": "John",
"lastName": "Smith",
"age": 25
}
脚注 #
脚注允许您添加注释和引用,而不会使文档正文变得混乱。创建脚注时,带有链接的上标数字会显示在添加脚注引用的位置。读者可以单击该链接跳转到页面底部的脚注内容。
要创建脚注引用,请在方括号 ([^1]
) 内添加插入符号和标识符。标识符可以是数字或单词,但不能包含空格或制表符。标识符仅将脚注引用与脚注本身相关联 — 在输出中,脚注按顺序编号。
使用另一个插入符号和括号内的数字添加脚注,并带有冒号和文本 ([^1]: 这是一个脚注
)。您不必在文档末尾放置脚注。您可以将它们放在除列表、块引用和表格等其他元素之外的任何位置。
这是一个脚注,[^1] 这里是完整版本.[^bignote]
[^1]: 这是一个脚注
[^bignote]: 下面是一个包含多个段落和代码的命令。
缩进段落以将其包含在脚注中。
`{ my code }`
根据需要添加任意数量的段落。
渲染输出结果如下:
缩进段落以将其包含在脚注中。
`{ my code }`
根据需要添加任意数量的段落。
标题ID #
许多 Markdown 处理器支持 标题的自定义 ID——一些 Markdown 处理器会自动添加它们。通过添加自定义 ID,您可以直接链接到标题并使用 CSS 对其进行修改。要添加自定义标题 ID,请将自定义 ID 括在与标题相同的行上的大括号中。
### 十三经 {#custom-id}
对应的HTML代码如下:
<h3 id="custom-id">十三经</h3>
链接到标题ID #
您可以通过创建带有数字符号 (#) 的标准 链接,后跟自定义标题 ID,从而链接到文件中具有自定义 ID 的标题。这些通常称为锚链接。
Markdown | HTML | 输出样式 |
---|---|---|
[标题ID](#custom-id) |
<a href="#custom-id">标题ID</a> |
标题ID |
其他网站可以通过将自定义标题ID添加到网页的完整 URL 来链接到标题(例如,[标题ID](https://markdown.hk/zh/docs/Extended-Syntax/#标题id)
)
定义列表 #
某些 Markdown 处理器允许您创建术语及其相应定义的定义列表。要创建定义列表,请在第一行键入术语。在下一行中,键入一个冒号,后跟一个空格和定义。
第一项
: 第一项的定义
第二项
: 第二项的一个定义
: 第二项的另一个定义
对应的HTML代码如下:
<dl>
<dt>第一项</dt>
<dd>第一项的定义</dd>
<dt>第二项</dt>
<dd>第二项的一个定义 </dd>
<dd>第二项的另一个定义</dd>
</dl>
渲染输出结果如下:
- 第一项
- 第一项的定义
- 第二项
- 第二项的一个定义
- 第二项的另一个定义
删除线 #
您可以通过在单词中心放置一条水平线来删除单词。结果如下所示。此功能允许您指示某些单词是错误,不应包含在文档中。要删除单词,请在单词前后使用两个波浪号(~~)。
~~世界是平的~~,我们现在知道世界是圆的。
输出结果如下:
世界是平的,我们现在知道世界是圆的。
任务列表 #
任务列表(也称为清单和待办事项列表)允许您创建带有复选框的项目列表。在支持任务列表的 Markdown 应用程序中,复选框将显示在内容旁边。要创建任务列表,请在任务列表项前面添加短划线 (-
) 和带空格 ([ ]
) 的括号。要选中复选框,请在方括号 ([x]
) 之间添加一个 x。
- [x] Write the press release
- [ ] Update the website
- [ ] Contact the media
输出结果如下:
表情符号 #
有两种方法可以将表情符号添加到 Markdown 文件中:将表情符号复制并粘贴到 Markdown 格式的文本中,或键入表情符号短代码。
复制和粘贴表情符号 #
在大多数情况下,您可以简单地从 Emojipedia 等来源复制表情符号并将其粘贴到您的文档中。许多 Markdown 应用程序会自动以 Markdown 格式的文本显示表情符号。您从 Markdown 应用程序导出的 HTML 和 PDF 文件应该显示表情符号。
提示:如果您使用的是静态站点生成器,请确保将HTML页面[编码为 UTF-8](https://www.w3.org/International/tutorials/tutorial-char-enc/)。
使用Emoji简码 #
一些 Markdown 应用程序允许您通过键入表情符号短代码来插入表情符号。这些图标以冒号开头和结尾,并包含表情符号的名称。
去露营了! :tent: 很快就会回来。
这太有趣了! :joy:
输出结果如下:
去露营了! ⛺ 很快就会回来。
这太有趣了! 😂
注意:您可以使用此表情符号[短代码列表](https://gist.github.com/rxaviers/7360908),但请记住,表情符号短代码因应用程序而异。有关更多信息,请参阅 Markdown 应用程序的文档。
高亮 #
这并不常见,但某些 Markdown 处理器允许您突出显示文本。结果如下所示。要突出显示单词,请在单词前后使用两个等号 (==
)。
念念不忘,必有==回响==。
输出结果如下:
念念不忘,必有回响。
或者,如果您的 Markdown 应用程序支持
HTML,则可以使用 mark
HTML 标签。
念念不忘,必有<mark>回响</mark>。
Subscript #
This isn’t common, but some Markdown processors allow you to use subscript to position one or more characters slightly below the normal line of type. To create a subscript, use one tilde symbol (~
) before and after the characters.
下标 #
这并不常用,但某些 Markdown 处理器允许您使用下标将一个或多个字符定位在正常类型行略低于正常行的位置。要创建下标,请在字符前后使用一个波浪号 (~
)。
H~2~O
输出结果如下:
H2O
提示: 在使用之前,请务必在 Markdown 应用程序中对此进行测试。一些 Markdown 应用程序在单词前后使用一个波浪号,而不是用于下标,而是用于[删除线](../extended-syntax/#删除线)。
或者,如果您的 Markdown 应用程序支持
HTML,则可以使用 sub
HTML 标记。
H<sub>2</sub>O
Superscript #
This isn’t common, but some Markdown processors allow you to use superscript to position one or more characters slightly above the normal line of type. To create a superscript, use one caret symbol (^
) before and after the characters.
上标 #
这并不常用,但某些 Markdown 处理器允许你使用上标将一个或多个字符定位在正常类型行的略高于正常行的位置。要创建上标,请在字符前后使用一个插入符号 (^
)。
km^3^
输出结果如下:
km3
或者,如果您的 Markdown 应用程序支持
HTML,则可以使用 sup
HTML 标记。
km<sup>3</sup>
自动URL链接 #
许多 Markdown 处理器会自动将 URL 转换为链接。这意味着如果你键入 http://markdown.hk,即使你没有 使用括号,你的 Markdown 处理器也会自动将其转换为链接。
http://markdown.hk
输出结果如下:
禁用自动 URL 链接 #
如果您不希望 URL 自动链接,您可以通过使用反引号将 URL 表示为 代码来禁用链接。
`http://markdown.hk`
输出结果如下:
http://markdown.hk