200316.Markdown基本语法,尽可能的全

[Markdown]01.Markdown基本语法,尽可能的全

Markdown是一种纯文本格式的轻量级标记语言。通过简单的标记语法,它可以使普通文本内容具有一定的格式。

当前许多网站都广泛使用Markdown来撰写帮助文档或者发布消息再或者发布博客,比如:Github、CSDN博客、、有道云笔记、Hexo等。那么下面来简单介绍一下Markdown的语法。

[TOC]

原文与正文内容的区别

Markdown是一种标记语言。

graph LR
原文-->编译器
编译器-->正文

原文是作者编写中使用的,里面包含标记字符。原文中的标记字符具有特殊意义,用来标识某些功能。

编译器用来将原谅转换为正文,将原谅中的标记符号转换为格式及图形。

正文显示时这些标记符号并不会显示。

示例,原文如下:

#### 这是四级标题
**这是加粗正文**

正文显示效果如下:

这是四级标题

这是加粗正文

示例中的,`、#、*都是标记符号,在显示中并不显示。

让标记符号在正文中显示

要想这些标记字符在正文显示出来,必须将\符号放在标记字符前。

示例,原文如下:

#### 原文中拥有标记符号的标题\#
**原文中拥有标记符号\*的正文**

正文显示效果如下:

原文中拥有标记符号的标题

原文中拥有标记符号*的正文

注意:\字符也是标记字符,它表示后面的标记字符不被原文识为标记语言的组成部分,将显示在正文当中。

标题

只要在文字前面加#,即可把这段文字设置为标题。一个#是一级标题,二个#是二级标题,以此类推。支持六级标题。

注意:标准语法一般在#后跟个空格再写文字,虽然现在某些markdown编辑器不用空格也可以,但是最好还是按照标准语法来。比如Typora编辑器中不空格就不会生成标题的样式。

示例,原文如下:

# 这是一级标题
## 这是二级标题
### 这是三级标题

正文显示效果如下:

这是一级标题


这是二级标题


这是三级标题

注释

如果你想某些信息不在正文中显示,只在原文中显示,可以使用注释语法。
语法格式如下:


示例,原文如下:


正式内容如下:

可以看到,在正文中是无法看到这些信息的。

脚注

脚注功能严格来说属于markdown的扩展语法里面。在使用上也有不同的"表达方式",例如我在不同的编辑器里面,如typora和mweb,以及Mdnice、坚果云的网页编辑都不一样的代码输入和渲染方式。

原文如下:

茅盾[^1]
[^1]: 我国著名的文学作家

正文内容如下:

茅盾[1]

序号

有时我们需要对文本进行自动编号时,可以使用如下格式来进行。

示例,原文如下:

1. 第一条
2. 第二条
3. 第三条

正文内容如下:

  1. 第一条
  2. 第二条
  3. 第三条

字体样式

在写具体内容的时候,可能需要对某些内容显示不一样的样式,以用于特别标注。那么Markdown支持以下四种样式:

  • 加粗 要加粗的文字左右分别用两个*号即可
  • 斜体 要倾斜的文字左右分别用一个*号即可
  • 斜体加粗 要倾斜和加粗的文字左右分别用三个*号即可
  • 删除线 要加删除线的文字左右分别用两个~号即可

示例,原文格式如下:

**加粗效果**
*斜体效果*
***斜体加粗效果***
~~删除效果~~

正文显示效果如下:

加粗效果

斜体效果

斜体加粗效果

删除效果

引用

在需要设为引用的文字前面加上>即可,引用也支持嵌套,原文如下:

> 一级引用
>> 二级引用
>>> 三级引用
以此类推

正文显示效果如下:

一级引用

二级引用

三级引用

分割线

一行连用三个或者三个以上的星号*,减号-,或者下划线_,就可以表示分割线。

示例,原文如下:

***
---
___

可以看到正文显示效果是一样的,如下:




图片

在Markdown中插入图片的语法如下

![Alt text](图片链接 "optional title")
  • Alt text:图片的Alt标签,用来描述图片的关键词,可以不写。最初的本意是当图片因为某种原因不能被显示时而出现的替代文字,后来又被用于SEO,可以方便搜索引擎根据Alt text里面的关键词搜索到图片。
    图片链接:可以是图片的本地地址或者是网址。
  • "optional title":鼠标悬置于图片上会出现的标题文字,可以不写。

超链接形式

只需要在基础语法的括号中填入图片的网络链接即可,现在已经有很多免费/收费图床和方便传图的小工具可选。

示例,原文内容:

![](https://www.baidu.com/img/bd_logo1.png?where=super "不要用百度")
效果如下

正文显示效果如下:
[图片上传失败...(image-21219a-1620097738447)]

本地图片

只需要在基础语法的括号中填入图片的位置路径即可,支持绝对路径和相对路径。

示例,原文内容下:

![avatar](/home/picture/1.png)

正文显示效果如下:
[图片上传失败...(image-ffc8b0-1620097738447)]

把图片存入markdown文件

用base64转码工具把图片转成一段字符串,然后把字符串填到基础格式中链接的那个位置。

基础用法:

![avatar](......)

这个时候会发现插入的这一长串字符串会把整个文章分割开,非常影响编写文章时的体验。如果能够把大段的base64字符串放在文章末尾,然后在文章中通过一个id来调用,文章就不会被分割的这么乱了。

高级用法,原文内容如下:

![avatar][base64str]
[base64str]:..... 

这种方法Atom、有道云笔记支持,不全部支持,并且只支持png图片文件格式,不推荐使用。

超链接

Markdown还支持超链接,语法格式如下:

[超链接名](超链接地址 "超链接title")

注意:title可加可不加

示例,原文内容如下:

[会蹦的小黑的博客](http://blog.dawnguo.cn "那是不可能的事")

正文显示效果如下:

会蹦的小黑的博客

注意:上面语法中[]中的内容为超链接名,那么[]其实可以不用文字,可以换成一张图片,如下

效果如下(微信公众号中暂不支持外部链接的跳转):

avatar
avatar

表格

Markdown还支持插入表格,语法如下

|表头|表头|表头|
|-|:-:|-:|
|内容|内容|内容|
|内容|内容|内容|

第二行分割表头和内容,同时也是表格居中居左居右的定义:

  • -符号有一个就行,多个也可以,只有-符号的话默认是居左
  • -符号两边加:表示文字居中
  • -符号右边加:表示文字居右

示例,原文显示如下:

| 公众号 | 好感度 | 点赞数 | 好评数 |
| - | :-: | -: |:-|
| 会蹦的小黑 | 99+ | 99+ | 99+ |
| 会蹦的小黑 | 99+ | 99+ | 99+ |

正文显示效率如下:

公众号 好感度 点赞数 好评数
会蹦的小黑 99+ 99+ 99+
会蹦的小黑 99+ 99+ 99+

代码块

Markdown最让人喜欢的一点就是支持代码高亮,并且支持数几十种语言的高亮,语法格式很简单。

多行示例

代码区块使用 4 个空格或者一个制表符(Tab 键)。
原文如下:

    print("代码块第一行")
    print("代码块第二行")

正文显示效果如下:

print("代码块第一行")
print("代码块第二行")

你也可以用 ``` 包裹一段代码,并指定一种语言(也可以不指定):

原文内容如下:

```python

print("代码块")

```

正文显示效果如下:

print("代码块")`

适用场景是单独的贴上一整段代码,那么在三个`之间插入代码即可。

单行示例

如你需要在一段文字中加入一小行代码,那么在两个`插入代码即可。

原文内容如下:

我们要在段落中使用代码块,比如`print("代码块")`。

正文显示效果如下:

我们要在段落中使用代码块,比如print("代码块")

目录

键入[TOC],之后回车目录便会呈现,目录树会根据文档中的h1~h6标题自动生成,并且支持点击跳转。

[TOC]

注意:[TOC]需要独占一行才能生效。

跳转到指定标题

手动添加跳转到某个标题的链接。使用如下的语法:

[名称](#id)

“名称”可以随便填写,“id”需要填写跳转到的标题的内容。
示例,原文内容:

[目录](#目录)

目录

注意:Markdown会自动给每一个h1~h6标题生成一个锚,其id就是标题内容。

在Markdown中画流程图

如何在Markdown中画流程图呢?当然是用mermaid了,mermaid支持三种图形的绘制, 分别是流程图, 时序图和甘特图, 本节只介绍了mermaid中流程图在markdown的使用。
如何在markdown中使用mermaid

如何在markdown中使用mermaid

graph 流程图方向
流程图内容

流程图方向有下面几个值:

  • TB 从上到下
  • BT 从下到上
  • RL 从右到左
  • LR 从左到右
  • TD 同TB
graph LR
原文-->编译器
编译器-->正文

正文效果如下:

graph LR
原文-->编译器
编译器-->正文

基本图形

  • id + [文字描述]矩形
  • id + (文字描述)圆角矩形
  • id + >文字描述]不对称的矩形
  • id + {文字描述}菱形
  • id + ((文字描述))圆形

原文示例如下:

graph TD
    id[带文本的矩形]
    id4(带文本的圆角矩形)
    id3>带文本的不对称的矩形]
    id1{带文本的菱形}
    id2((带文本的圆形))

正文显示效果如下:

graph TD
    id[带文本的矩形]
    id4(带文本的圆角矩形)
    id3>带文本的不对称的矩形]
    id1{带文本的菱形}
    id2((带文本的圆形))

节点之间的连接
A --> B A带箭头指向B
A --- B A不带箭头指向B
A -.- B A用虚线指向B
A -.-> B A用带箭头的虚线指向B
A ==> B A用加粗的箭头指向B
A -- 描述 --- B A不带箭头指向B并在中间加上文字描述
A -- 描述 --> B A带箭头指向B并在中间加上文字描述
A -. 描述 .-> B A用带箭头的虚线指向B并在中间加上文字描述
A == 描述 ==> B A用加粗的箭头指向B并在中间加上文字描述

mermaid
graph LR
    A[A] --> B[B] 
    A1[A] --- B1[B] 
    A4[A] -.- B4[B] 
    A5[A] -.-> B5[B] 
    A7[A] ==> B7[B] 
    A2[A] -- 描述 --- B2[B] 
    A3[A] -- 描述 --> B3[B] 
    A6[A] -. 描述 .-> B6[B] 
    A8[A] == 描述 ==> B8[B] 
graph LR
    A[A] --> B[B] 
    A1[A] --- B1[B] 
    A4[A] -.- B4[B] 
    A5[A] -.-> B5[B] 
    A7[A] ==> B7[B] 
    A2[A] -- 描述 --- B2[B] 
    A3[A] -- 描述 --> B3[B] 
    A6[A] -. 描述 .-> B6[B] 
    A8[A] == 描述 ==> B8[B] 

子流程图
格式

subgraph title
    graph definition
end

示例

mermaid
graph TB
    c1-->a2
    subgraph one
    a1-->a2
    end
    subgraph two
    b1-->b2
    end
    subgraph three
    c1-->c2
    end

效果:

graph TB
    c1-->a2
    subgraph one
        a1-->a2
    end
    subgraph two
        b1-->b2
    end
    subgraph three
        c1-->c2
    end

时序图

sequenceDiagram
    participant Alice
    participant Bob
    Alice->>John: Hello John, how are you?
    loop Healthcheck
        John->>John: Fight against hypochondria
    end
    Note right of John: Rational thoughts 
prevail! John-->>Alice: Great! John->>Bob: How about you? Bob-->>John: Jolly good!

甘特图

gantt
    title A Gantt Diagram
    dateFormat  YYYY-MM-DD
    section Section
        A task           :a1, 2014-01-01, 30d
        Another task     :after a1  , 20d
    section Another
        Task in sec      :2014-01-12  , 12d
        another task      : 24d

原文是网页版本,里面添加了不少广告,影响学习使用。本文是自己对原文按照自己的学习方式进行修改改进的,如果不喜欢请看原文链接。

由于原文是是发布在微信当中,微信的分享链接是每天变化的,所以只能提供原文的搜索链接,请见谅。


  1. 我国著名的文学作家
    茅盾1 ↩

你可能感兴趣的:(200316.Markdown基本语法,尽可能的全)