# Markdown指南 Markdown是一种轻量级的易用的书写语法。本文是Markdown的一个快速指南[^1]。 ## 什么是Markdown? Markdown是一种通过少量简单的标记字符来格式化文本的方法。您可以用纯文本来书写文档,然后在阅读时呈现一个美观的排版。 其实并没有一个标准的Markdown语法,很多编辑器都会添加自己的扩展语法。不同于此,为了兼容性,VNote仅仅支持那些被广泛使用的基本语法。 ## 如何上手Markdown? 如果您是刚接触Markdown,那么比较好的一个方法是逐个学习Markdown语法。刚开始,懂得标题和强调语法就能够写出基本的文档;然后,每天可以学习一个新的语法并不断练习。 ## 语法指南 下面是VNote支持的Markdown语法的一个概览。 ### 标题 ```md # This is an

tag ## This is an

tag ###### This is an

tag ``` **注意**: - `#`之后需要至少一个空格; - 一个标题应该占一整行; ### 强调 ```md *This text will be italic* _This text will be italic_ **This text will be bold** __This text will be bold__ ``` **注意**: - VNote推荐使用`*`; - 如果渲染错误,请尝试在第一个`*`之前以及最后一个`*`之后添加一个空格。如果被标记的文本是以全角符号开始或结尾,一般都需要前后添加一个空格; - VNote提供快捷键`Ctrl+I`和`Ctrl+B`来插入斜体和粗体; ### 列表 #### 无序列表 ```md * Item 1 只是一段在Item 1下面的文字。需要注意上面一行结尾有两个空格。 * Item 2 * Item 2a * Item 2b * Item 3 使用一个空行来来结束一个列表。 ``` #### 有序列表 ```md 1. Item 1 1. Item 2 注意,列表前面的序号其实是无关紧要的,渲染时Markdown会自动修改该序号。 3. Item 3 1. Item 3a 2. Item 3b 4. Item 4 ``` ### 表格 ```md | col 1 | col 2 | col 3 | | --- | --- | --- | | cell1 | cell2 | cell3 | | cell4 | cell5 | cell6 | ``` ### 图片和链接 ```md ![Image Alt Text](/url/to/image.png "Optional Text") ![Image Alt Text](/url/to/image.png "Image specified with width and height" =800x600) ![Image Alt Text](/url/to/image.png =800x600) ![Image Alt Text](/url/to/image.png "Image specified with width" =800x) ![Image Alt Text](/url/to/image.png "Image specified with height" =x600) [Link Text](/url/of/the/link) ``` **注意**: - VNote不推荐使用参考式的图片链接。VNote不会预览这些图片。 - 声明图片尺寸只在 **markdown-it** 中支持。 ### 块引用 ```md As VNote suggests: > VNote is the best Markdown note-taking application > ever. > > THere is two spaces after `ever.` above to insert a > new line. ``` **注意**: - `>`标记后面需要至少一个空格; - 多行连续的引用可以只在第一行添加标记; ### 代码块 ```lang This is a fenced code block. ``` **注意**: - `lang`用于指定代码块的代码语言,可选; ### 图表 > 需要在`Markdown`菜单中启用Flowchart.js或Mermaid。 VNote支持 [Flowchart.js](http://flowchart.js.org/) 和 [Mermaid](https://mermaidjs.github.io/) 来实现诸如*流程图*和*序列图*等图表。您需要使用代码块,并标明语言为`flow`或`flowchart`或`mermaid`,然后在代码块里面定义图表。 ```flowchart st=>start: Start:>http://www.google.com[blank] e=>end:>http://www.google.com op1=>operation: My Operation sub1=>subroutine: My Subroutine cond=>condition: Yes or No?:>http://www.google.com io=>inputoutput: catch something... st->op1->cond cond(yes)->io->e cond(no)->sub1(right)->op1 ``` #### UML > 需要在设置中启用PlantUML。如果使用在线的PlantUML服务器,请注意隐私问题;如果使用本地PlantUML,可能需要安装Java运行时、PlantUML以及Graphviz。 VNote支持 [PlantUML](http://plantuml.com/) 来实现UML图表。您需要使用代码块,并标明语言为`puml`,然后在代码块里面定义图表。 ```puml @startuml Bob -> Alice : hello @enduml ``` #### Graphviz > 需要在设置中启用Graphviz。 VNote支持 [Graphviz](http://www.graphviz.org/) 来绘制图表。您需要使用代码块,并标明语言为`dot`,然后在代码块里面定义图表。 ### 数学公式 > 需要在`Markdown`菜单中启用MathJax,并重启VNote。 VNote通过 [MathJax](https://www.mathjax.org/) 来支持数学公式。默认的**块公式**的分隔符是`$$...$$`,**行内公式**的分隔符是`$...$`。 - 行内公式不能跨多行; - 形如`3$abc$`/`$abc$4`/`$ abc$`和`$abc $`的不会被解析为公式; - 使用`\`转义`$`; - 开始的`$$`之前以及结束的`$$`之后都只允许出现空格字符; VNote也可以使用标明语言`mathjax`的代码块来实现块公式。 ```mathjax $$ J(\theta) = \frac 1 2 \sum_{i=1}^m (h_\theta(x^{(i)})-y^{(i)})^2 $$ ``` ### 行内代码 ```md Here is a `inline code`. ``` 如果想输入一个 `` ` ``,需要使用两个 `` ` `` 来括住它,例如 ``` `` ` `` ```。 要输入两个 `` ` ``,则需要使用三个 `` ` ``。 ### 删除线 ```md Here is a ~~text~~ with strikethrough. ``` **注意**: - VNote提供快捷键`Ctrl+D`来插入带有删除线的文本; ### 任务列表 ```md - [x] this is a complete item. - [ ] this is an incomplete item. ``` ### 脚注 ```md This is a footnote [^1]. [^1]: Here is the detail of the footnote. ``` ### 换行和段落 如果需要换行,您应该在当前行末尾添加两个空格,然后换行。VNote提供快捷键`Shift+Enter`来辅助用户输入两个空格并换行。 如果需要一个新的段落,您应该先插入一个空行然后才输入新的段落的文本。 一般来说,您应该在一个块元素(例如代码块、列表和块引用)后面插入一个空行来显式结束该元素。 [^1]: 该指南参考了 [Mastering Markdown](https://guides.github.com/features/mastering-markdown/).