概览
Markdown 是一种标记语言(轻量级的、可用纯文本编写);
Markdown 诞生于2004年,由约翰·格鲁伯(John Gruber)创建;
Markdown 编写的文档可以导出 HTML 、Word、图像、PDF、Epub 等多种格式。
Markdown 编写的文档后缀为 .md, .markdown。
宗旨
Markdown 的目标是实现「易读易写」。
应用
Markdown 能被使用来撰写电子书,如:Gitbook。
当前许多网站都广泛使用 Markdown 来撰写帮助文档或是用于论坛上发表消息。例如:GitHub、简书、reddit、Diaspora、Stack Exchange、OpenStreetMap 、SourceForge等。
编辑器
Markdown编辑器目前颇多,可参考以下链接进行选择。
[传送门] https://blog.csdn.net/qq_36759224/article/details/82229243
区块元素
段落和换行
Markdown段落由一个或多个连续的文本行组成。
Markdown换行由两个及已上的空格加回车实现。
标题
Markdown 支持两种标题的语法,类Setext 和 Atx形式。
使用 = 和 - 标记一级和二级标题(类Setext)
1 | 我展示的是一级标题 |
注:任何数量的 = 和 - 都可以有效果。
使用 # 号标记 1-6 级标题(类Atx)
1 | # 一级标题 |
区块引用 Blockquotes
Markdown 标记区块引用是在每行的最前面加上 > ,如下:
1 | > This is a blockquote with two paragraphs. Lorem ipsum dolor sit amet, |
或在整个段落的第一行最前面加上 > :
1 | > This is a blockquote with two paragraphs. Lorem ipsum dolor sit amet, |
区块引用可以嵌套(例如:引用内的引用),只要根据层次加上不同数量的 > :
1 | This is the first level of quoting. |
引用的区块内也可以使用其他的 Markdown 语法,包括标题、列表、代码区块等:
1 | > ## 这是一个标题。 |
列表
Markdown支持有序列表和无序列表。
无序列表
无序列表使用星号、加号或是减号作为列表标记:
1 | * 无序列表 |
有序列表
有序列表则使用数字接着一个英文句点,然后加至少一个空格:
1 | 1. Bird |
注:列表上的数字不会影响输出的 HTML 结果
代码区块
Markdown 实现代码区块只要简单地缩进 4 个空格或是 1 个制表符就可以;
一个代码区块会一直持续到没有缩进的那一行(或是文件结尾)。
在代码区块里面, & 、 < 和 > 会自动转成 HTML 实体。
代码区块中,一般的 Markdown 语法不会被转换,像是星号便只是星号。
分割线
在一行中用三个以上的星号、减号、底线来建立一个分隔线,行内不能有其他东西。
1 | *** |
区段元素
链接
Markdown 支持两种形式的链接语法: 行内式和参考式两种形式。
不管是哪一种,链接文字都是用 [方括号] 来标记。
行内式
建立一个行内式的链接,只要在方块括号后面紧接着圆括号并插入网址链接即可,如果你还想要加上链接的title文字,只要在网址后面,用双引号把title文字包起来即可
1 | This is [an example](http://example.com/ "Title") inline link. |
如果你是要链接到同样主机的资源,你可以使用相对路径:
1 | See my [About](/about/) page for details. |
参考式
在链接文字的括号后面再接上另一个方括号,而在第二个方括号里面要填入用以辨识链接的标记:
1 | This is [an example][id] reference-style link. |
你也可以选择性地在两个方括号中间加上一个空格:
1 | This is [an example] [id] reference-style link. |
接着,在文件的任意处,你可以把这个标记的链接内容定义出来:
1 | [id]: http://example.com/ "Optional Title Here" |
隐式链接标记功能让你可以省略指定链接标记,这种情形下,链接标记会视为等同于链接文字,要用隐式链接标记只要在链接文字后面加上一个空的方括号,如果你要让 “Google” 链接到 google.com,你可以简化成:
1 | [Google][] |
然后定义链接内容:
1 | [Google]: http://google.com/ |
注:链接辨别标签可以有字母、数字、空白和标点符号,但是并不区分大小写,链接的定义可以放在文件中的任何一个地方,我比较偏好直接放在链接出现段落的后面,你也可以把它放在文件最后面,就像是注解一样。
强调
Markdown 使用星号(*)和底线(_)作为标记强调字词的符号。
1 | *single asterisks* |
注:用什么符号开启标签,就要用什么符号结束,强调可以出现在文字中间,但如果*和_两边都有空白的话,它们将被当成普通的符号。
如果要在文字前后直接插入普通的星号或底线,你可以用反斜线:
1 | \*this text is surrounded by literal asterisks\* |
代码
如果要标记一小段行内代码,你可以用反引号把它包起来(`),例如:
1 | Use the `printf()` function. |
如果要在代码区段内插入反引号,你可以用多个反引号来开启和结束代码区段:
1 | ``There is a literal backtick (`) here.`` |
代码区段的起始和结束端都可以放入一个空白,起始端后面一个,结束端前面一个,这样你就可以在区段的一开始就插入反引号:
1 | A single backtick in a code span: `` ` `` |
在代码区段内,& 和方括号都会被自动地转成 HTML 实体,这使得插入 HTML 原始码变得很容易,Markdown 会把下面这段:
图片
Markdown 使用一种和链接很相似的语法来标记图片,同样也允许两种样式:行内式和参考式。
行内式:
1 | ![Alt text](/path/to/img.jpg) |
详细叙述如下:
- 一个惊叹号 !
- 接着一个方括号,里面放上图片的替代文字
- 接着一个普通括号,里面放上图片的网址,最后还可以用引号包住并加上 选择性的 ‘title’ 文字。
参考式:
1 | ![Alt text][id] |
「id」是图片参考的名称,图片参考的定义方式则和连结参考一样:
1 | [id]: url/to/image "Optional title attribute" |
到目前为止, Markdown 还没有办法指定图片的宽高,如果你需要的话,你可以使用普通的<img>
标签。
其它
反斜杠
Markdown 可以利用反斜杠来插入一些在语法中有其它意义的符号,例如:如果你想要用星号加在文字旁边的方式来做出强调效果(但不用 <em> 标签),你可以在星号的前面加上反斜杠:
1 | \*literal asterisks\* |
Markdown 支持以下这些符号前面加上反斜杠来帮助插入普通的符号:
1 | \ 反斜线 |
自动链接
Markdown 支持以比较简短的自动链接形式来处理网址和电子邮件信箱,只要是用方括号包起来, Markdown 就会自动把它转成链接。一般网址的链接文字就和链接地址一样,例如:
1 | <http://example.com/> |
Markdown 会转为:
1 | <a href="http://example.com/">http://example.com/</a> |
邮址的自动链接也很类似,只是 Markdown 会先做一个编码转换的过程,把文字字符转成 16 进位码的 HTML 实体,这样的格式可以糊弄一些不好的邮址收集机器人,例如:
1 | <address@example.com> |
Markdown 会转成:
1 | <a href="mailto:addre |
在浏览器里面,这段字串(其实是 <a href="mailto:address@example.com">address@example.com</a>
)会变成一个可以点击的「address@example.com」链接。