用Typora工具快速编写MarkDown格式的文章

Typora简介

Typora是一款跨平台的Markdown编辑器软件,拥有Windows、macOS客户端。Typora支持MarkDown的标准语法,同时这款软件还支持动态预览功能,一键预览。”

Typora界面

优点:界面简洁,编写所需功能应有尽有,可以打开左侧窗口管理当前文件夹的文档、查看当前文档大纲,功能很实用,编写MarkDown文档的利器!语法敲完即刻渲染完成,并显示预览效果。集成了Word和MarkDown的优点,使用体验很棒!

语法

这篇文章介绍使用Typora基于MarkDown语法写文章!

一到五和上篇文章没什么区别,可以直接跳过

一、标题

在想要设置为标题的文字前面加#来表示
一个#是一级标题,二个#是二级标题,以此类推。支持六级标题。

注:标准语法一般在#后跟个空格再写文字,貌似简书不加空格也行。

示例:

1
2
3
4
5
6
# 这是一级标题
## 这是二级标题
### 这是三级标题
#### 这是四级标题
##### 这是五级标题
###### 这是六级标题

效果如下:

这是一级标题

这是二级标题

这是三级标题

这是四级标题

这是五级标题
这是六级标题

二、字体

  • 加粗

要加粗的文字左右分别用两个*号包起来

  • 斜体

要倾斜的文字左右分别用一个*号包起来

  • 斜体加粗

要倾斜和加粗的文字左右分别用三个*号包起来

  • 删除线

要加删除线的文字左右分别用两个~~号包起来

示例:

1
2
3
4
**这是加粗的文字**
*这是倾斜的文字*`
***这是斜体加粗的文字***
~~这是加删除线的文字~~

效果如下:

这是加粗的文字
这是倾斜的文字
这是斜体加粗的文字
这是加删除线的文字


三、引用

在引用的文字前加>即可。引用也可以嵌套,如加两个>>三个>>>
n个…
貌似可以一直加下去,字体会逐级放大。

引用在GitHub上不好使。

示例:

1
2
3
>这是引用的内容
>>这是引用的内容
>>>>>>>>>>这是引用的内容

效果如下:

这是引用的内容

引用的内容

四、分割线

三个或者三个以上的 - 或者 * 都可以。

示例:

1
2
3
4
---
----
***
*****

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





五、图片

语法:

1
2
3
4
![图片alt](图片地址 "图片title")

图片alt就是显示在图片下面的文字,相当于对图片内容的解释。
图片title是图片的标题,当鼠标移到图片上时显示的内容。title可加可不加

示例:

1
2
![blockchain](https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/
u=702257389,1274025419&fm=27&gp=0.jpg "区块链")

效果如下:

网图

上传本地图片直接点击导航栏的图片标志,选择图片即可

markdown格式追求的是简单、多平台统一。那么图片的存储就是一个问题,需要用图床,提供统一的外链,这样就不用在不同的平台去处理图片的问题了。才能做到书写一次,各处使用。

六、超链接

语法:

1
2
[超链接名](超链接地址 "title")
title可加可不加,加了鼠标进过时会显示title的内容

示例:

1
2
[简书](http://jianshu.com)
[百度](http://baidu.com)

效果如下:

简书
百度


七、列表

无序列表

语法:
无序列表用 - + * 任何一种都可以

1
2
3
4
5
- 列表内容
+ 列表内容
* 列表内容

注意:- + * 跟内容之间都要有一个空格

效果如下:

  • 列表内容
  • 列表内容
  • 列表内容
有序列表

语法:
数字加点加空格

1
2
3
4
5
1. 列表内容
2. 列表内容
3. 列表内容

注意:序号跟内容之间要有空格

效果如下:

  1. 列表内容
  2. 列表内容
  3. 列表内容
列表嵌套

上一级完成后回车自动生成同级,按下backspace键后输入再次输入列表格式(- + * 或数字加空格)就行

或者直接续上一级的列表格式然后按tab键自动调整缩进到下一级

  • 一级无序列表内容
    • 二级无序列表内容
    • 二级无序列表内容
    • 二级无序列表内容
  • 一级无序列表内容
    1. 二级有序列表内容
    2. 二级有序列表内容
    3. 二级有序列表内容
  1. 一级有序列表内容
    • 二级无序列表内容
    • 二级无序列表内容
    • 二级无序列表内容
  2. 一级有序列表内容
    1. 二级有序列表内容
      1. 三级有序内容
      2. 三级有序内容
    2. 二级有序列表内容
    3. 二级有序列表内容

八、表格

语法:

1
2
输入表头后回车
|表头|表头|表头|

示例:

1
2
|姓名|技能|排行|
enter键

效果如下:

姓名 技能 排行

然后输入内容即可。现在版本这里跟word一样处理,很方便了!

九、代码

语法:
单行代码:代码之间分别用一个反引号包起来

1
`代码内容`

代码块:代码之间分别用三个反引号包起来,且两边的反引号单独占一行

1
2
3
4
5
(```)
enter键
代码...
代码...
代码...

注:为了防止转译,前后三个反引号处加了小括号,实际是没有的。这里只是用来演示,实际中去掉两边小括号即可。

示例:

单行代码

1
`create database hero;`

代码块

1
2
3
4
5
(```)
function fun(){
echo "这是一句非常牛逼的代码";
}
fun();

效果如下:

单行代码

1
create database hero;

代码块

1
2
3
4
function fun(){
echo "这是一句非常牛逼的代码";
}
fun();

十、流程图

1
2
```flow   
enter键

就会显示这样的空模板流程图空模板

然后输入代码:

1
2
3
4
5
6
7
8
9
10
11
st=>start: 开始
op=>operation: 画流程图
stu=>operation: 去学习
cond=>condition: 会不会画?
e=>end: 结束

st->op->cond
cond(no)->stu
stu->e
cond(yes)->e

先是用=>定义start、operation、condition、end的代号分别对应不同的框样式;然后用->定义路径。

效果如下:

Typora流程图效果

十一、时序图

复现微信支付的时序图

语法:

1
<pre class="mermaid">    ……时序图代码……</pre>

代码:

1
2
3
4
5
6
7
sequenceDiagram
小程序 ->> 小程序 : wx.login()获取code
小程序 ->> + 服务器 : wx.request()发送code
服务器 ->> + 微信服务器 : code+appid+secret
微信服务器 -->> - 服务器 : openid
服务器 ->> 服务器 : 根据openid确定用户并生成token
服务器 -->> - 小程序 : token

效果:

再演示一个微信支付的流程图

代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
sequenceDiagram
title: 微信支付时序图
participant 微信支付用户 as user
participant 微信客户端 as wxc
participant 商户APP客户端 as appc
participant 商户后台系统 as apps
participant 微信支付系统 as wxs

user->appc:1.打开商户APP客户端()
appc->appc:2.选择商品下单()
appc->apps:3.请求生成支付订单()
apps->wxs:4.调用统一下单API()
wxs->wxs:生成预付单()
wxs-->>apps:5.返回预付单信息(prepay_id)
apps->apps:6.生成带签名的客户端支付信息()
apps-->>appc:7:返回信息(prepay_id,sign等)
user->appc:8:用户确认支付()
appc-->wxc:9:支付参数通过调用SDK调起微信支付()
wxc->wxs:10.发起支付请求()
wxs->wxs:验证支付参数, APP支付权限等()
wxs-->>wxc:11.返回需要支付授权()
user->wxc:12.用户确认支付, 输入密码()
wxc->wxs:13:提交支付授权()
wxs->wxs:验证授权, 完成支付交易()
wxs-->>apps:15.异步通知商户支付结果()
apps->apps:接收和保存支付通知()
apps->>wxs:16.返回告知已成功接收处理()
wxs-->wxc:14.返回支付结果, 发送微信消息提示()
wxc->appc:将支付状态通过商户APP已实现的回调接口执行回调()
appc->apps:后台查询实际支付结果()
apps->wxs:调用微信查询API查询支付结果()
wxs-->>apps:返回支付结果()
apps-->appc:返回支付结果
appc-->user:展示支付结果()
appc->appc:商户发货()

效果:

微信支付时序图

十二、饼图

饼图使用 pie 表示,标题下面分别是区域名称及其百分比。

格式:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<pre class="mermaid">    饼图代码</pre>

代码:

```vbnet
pie
title Key elements in Product X

"Calcium" : 42.96

"Potassium" : 50.05

"Magnesium" : 10.01

"Iron" : 5

效果:

参考链接1:https://www.jianshu.com/p/191d1e21f7ed

参考链接2:https://www.jianshu.com/p/7fa30d7d6fd5

makdown支持html语言

居中

对于标准的markdown文本,是不支持居中对齐的。还好markdown支持html语言,所以我们采用html语法格式即可。

1
<center>这一行需要居中</center>
这一行需要居中

颜色

对于html语音中,颜色是用color来表示,所以可以表示如下

1
<font color=red size=72>颜色</font>

颜色