Markdown使用指南与总结

一、简单介绍Markdown

Markdown 是一种轻量级标记语言,创始人为约翰·格鲁伯(John Gruber)。

Markdown 允许人们使用易读易写的纯文本格式编写文档,然后转换成有效的HTML文档。

Markdown 编写的文档可以导出 HTML 、Word、图像、PDF、Epub 等多种格式的文档。

Markdown 编写的文档后缀为 .md, .markdown。

markdown的流行程度足以说明其带来便利程度,

许多网站平台的文章、博客、论文都是基于它之手的

例如:

国外的GitHub、Reddit、Diaspora、Stack Exchange、OpenStreetMap 、SourceForge等;

国内的CSDN、简书、掘金、博客园、知乎等

二、Markdown的基本语法

2.1 标题

[ #级数 + _空格 + 标题内容 ]

使用#号标记,可以表示1-6级标题

#的个数递增,字号逐渐缩小,一级标题字号最大,六级标题字号最小。

代码

# 一级标题
## 二级标题
### 三级标题
#### 四级标题
##### 五级标题
###### 六级标题

效果

*注意

最后一个#字符与标题中间留一个空格

标题应该置于行首,如果放入表格中可能无法正确解析

2.2 字体

[ 星号下划线 都可以

单是斜体,双是粗体,三是粗斜体 ]

代码效果
*这是斜体*这是斜体
_这是斜体_这是斜体
**这是粗体**这是粗体
__这是粗体__这是粗体
***这是粗斜体***这是粗斜体
___这是粗斜体___这是粗斜体

快捷键:

加粗Ctrl+B

斜体Ctrl+I


2.3 换行

Markdown换行的方式有很多种:

[1. 直接在一句话后敲两个空格
2. 两句话之间加一个空行
3. 如果你在编辑的时候,想让一行文字在显示的时候换行,就在中间加<br/> ]

2.4 引用

[引用通过符号 > 来实现。> 符号后的空格,可有可无。]

在引用的区块内,允许换行存在,换行并不会终止引用的区块。如果要结束引用,需要一行空白行,来结束引用的区块。

代码

>这是一个引用

效果

这是一个引用

注意:此外,引用还可以嵌套使用

代码

>这是一个引用:
>>这是一个引用的引用
>>>这是一个引用的引用的引用

效果

这是一个引用

这是一个引用的引用

这是一个引用的引用的引用


2.5 链接

插入链接

(1)编写语法

代码

1. [链接名称](链接地址)
[Nini的主页](https://blog.csdn.net/NiNi_suanfa?spm=1010.2135.3001.5421)
 2. <链接地址>
<https://blog.csdn.net/NiNi_suanfa?spm=1010.2135.3001.5421>

效果

Nini的主页

https://blog.csdn.net/NiNi_suanfa?spm=1010.2135.3001.5421

(2)快捷键
  1. CSDN中的MD编辑器,上方的工具栏中的 “ 超链接 ” 可直接添加链接,省去写语法的麻烦

2.然后在方框中复制粘贴链接 点击确认即可

3.在网址前的 [ ] 可改关于链接的描述

2.6 图片

插入图片

  • ![图片描述,可写可不写,但是中括号要有](图片地址,本地链接或者URL地址。)
  • Ctrl+v

代码

![NiNi](https://ucc.alicdn.com/images/user-upload-01/e7bcc817c5b14ee09e32b3cab1b7c72e.png)

2.7 列表

列表分为有序列表和无序列表

  • 无序列表 :使用*+-,再加一个空格作为列表的标记 (三者之一即可)
  • 有序列表 :使用数字并加上.号,再加一个空格作为列表的标记

代码

* 无序列表 1
+ 无序列表 2
- 无序列表 3
1. 有序列表 1
2. 有序列表 2
3. 有序列表 3

效果

  • 无序列表 1
  • 无序列表 2
  • 无序列表 3
  1. 有序列表 1
  2. 有序列表 2
  3. 有序列表 3

如果想要 控制列表的层级 ,则需要在列表符号前使用 Tab

代码

+ 无序列表 1
+ 无序列表 2
	+ 无序列表 2.1
	+ 无序列表 2.2
1. 有序列表 1
	1.1 有序列表 1.1
2. 有序列表 2
	2.1 有序列表2.1

效果

  • 无序列表 1
  • 无序列表 2
  • 无序列表 2.1
  • 无序列表 2.2
  1. 有序列表 1
    1.1 有序列表 1.1
  2. 有序列表 2
    2.1 有序列表2.1

2.8 分割线

多种分割线的样式

在一行中用三个 - or * 来建立一个分割线

注意:在分割线的上面空一行!!

代码

分割线:
---
***
- - -
* * *

效果





注意:写分割线前,要空一行之后写,否则会导致前一行字体放大。


2.9 删除线

添加删除线的文字前后添加两个~

代码

~~这是要被删除的文字~~

效果

这是要被删除的文字


2.10 下划线

需添加下划线的文字 首尾 添加 <u>文本</u>

代码

<u>这行文字已被添加下划线</u>

效果

这行文字已被添加下划线


2.11 代码块

  • 一行内引用代码, 反引号` 引起来
  • 一个块内引用代码, 在需要引用的代码块的前一行和后一行使用三个反引号,同时在前一个反引号后 写入代码的语言

代码

一行
`Hello` World.
一块
```c
#include<stdio>
int main(){
printf("HelloWorld");
}
(```)实际中无()

效果

Hello World.

#include<stdio>
int main(){
printf("HelloWorld");
}

支持以下语言:

bash
c,clojure,cpp,cs,css
dart,dockerfile, diff
erlang
go,gradle,groovy
haskell
java,javascript,json,julia
kotlin
lisp,lua
makefile,markdown,matlab
objectivec
perl,php,python
r,ruby,rust
scala,shell,sql,swift
tex,typescript
verilog,vhdl
xml
yaml