markdown mermaid流程图
流程图
所有流程图都由节点、几何图像、箭头或线条组成。 mermaid代码定义了这些节点和边的制作和交互方式。可以有不同的箭头类型、多向箭头以及与子图的连接。
节点
节点
flowchart LR
id
id
带文字的节点
可以在框中设置与id不同的文本。如果多次这样做,将使用的节点的最后一个文本。另外,如果稍后为节点定义边,则可以省略文本定义。之前定义的将在呈现框时使用。
flowchart LR
node[id text]
node[id text]
节点形状
| 图形 | 示例 | 备注 |
|---|---|---|
| 方形 | id[方形] | |
| 圆角 | id(圆角) | |
| 圆形 | id((圆)) | |
| 体育场 | id([体育场]) | |
| 圆柱 | id[(圆柱)] | 可以表示数据库 |
| 子程序 | id[[子程序]] | |
| 不对称 | id>不对称] | |
| 菱形 | id{条件} | 可以作为判断 |
| 六角形 | id{{六角形}} | |
| 平行四边形 | id[/平行四边形/] | |
| 平行四边形 | id[\平行四边形\] | |
| 梯形 | id[/梯形\] | |
| 梯形 | id[\梯形/] |
方形节点
flowchart TB
A[默认节点]
A[默认节点]
圆角节点
flowchart TB
A(圆角节点)
A(圆角节点)
圆形节点
flowchart LR
A((圆形))
A((圆形))
体育场节点
flowchart TB
A([体育场节点])
A([体育场节点])
圆柱节点
flowchart LR
A[(圆柱形)]
A[(圆柱形)]
子程序形状节点
flowchart LR
A[[子程序形状]]
A[[子程序形状]]
不对称形状节点
flowchart LR
A>不对称形状]
A>不对称形状]
菱形节点
flowchart LR
A{菱形}
A{菱形}
六角形
flowchart LR
A{{六角形}}
A{{六角形}}
平行四边行节点
flowchart BT
A[\平行四边形\]
B[/平行四边形/]
A[\平行四边形\]
B[/平行四边形/]
梯形节点
flowchart LR
A[/梯形\] B[\梯形/]
A[/梯形\] === B[\梯形/]
子程序形状节点
flowchart LR
A[[子程序形状]]
A[[子程序形状]]
定义流程图的方向
| 方向 | 描述 |
|---|---|
| TB或者TD | 从上到下。默认 |
| BT | 从下到上 |
| LR | 从左到右 |
| RL | 从右到左 |
声明流程图从上到下(TD 或 TB)。
flowchart
A-->B
A-->B
声明了流程图是从左到右(LR)的方向。
flowchart LR
A-->B
A-->B
节点连接
分类
节点可以与连接/边连接。 可以有不同类型的连接,也可以将文本字符串附加到连接。
分类如下:
l[连接]-->x[线形]-->P[单线] & C[粗线] & X[虚线]
P-->PD["--"]
C-->CD["=="]
X-->XD["-.-"]
l-->箭头--> jy[有箭头] & jw[无箭头]
jy-->jyD[" "]
jw-->jwD[">"]
l-->注释-->zy(有注释) & zw(无注释)
线性和箭头的分类
根据线形、箭头(还有其他形状,但先默认为箭头,其他形状下面阐述)和注释(描述)的分类,可以有12种形式的连接形式:
| 表述 | 说明 | 使用示例 |
|---|---|---|
| --- | 单线无箭头 | A(出去游玩)---B[回家] |
| --> | 单线加箭头 | A(出去游玩)-->B[回家] |
| --text-- | 单线加描述 | A(出去游玩)--玩够了--B[回家] |
| --text--> | 单线箭头加描述 | A(出去游玩)--玩够了-->B[回家] |
| === | 粗线 | A(出去游玩)===B[回家] |
| ==> | 粗线加箭头 | A(出去游玩)==>B[回家] |
| == text== | 粗线加描述 | A(出去游玩)== 玩够了==B[回家] |
| == text==> | 粗线箭头加描述 | A(出去游玩)== 玩够了==>B[回家] |
| -.- | 虚线 | A(出去游玩) -.-[回家] |
| -.-> | 虚线加箭头 | A(出去游玩)-.->B[回家] |
| -.text.- | 虚线加描述 | A(出去游玩)-.玩够了.-B[回家] |
| -.text.-> | 虚线箭头加描述 | A(出去游玩)-.玩够了.->B[回家] |
连接详细例
单线带箭头的连接
flowchart LR
A-->B
c<-->|双向箭头|c1
A1--->B1
A-->B
c<-->|双向箭头|c1
A1--->B1
最少2条线。超过2条连接就会越长。其他连接同样的道理。
粗线带箭头连接
flowchart LR
A==>B
A==>B
虚线带箭头连接
flowchart LR
A-.->B
A-.->B
普通没有箭头的连接
flowchart LR
A---B
A---B
粗线没有箭头连接
flowchart LR
A===B
A===B
虚线无箭头连接
flowchart LR
A-.-B
A-.-B
有文字的连接
flowchart LR
A1-->|hello world|B1
A11--"hello world<br>另种方式"-->B11
ca11==>|hello world|ca21
ca1=="hello world<br>另种方式"==>ca2
xa-.->|I like the world|xa1
xa11-."I like the world<br>另种方式".->xa111
A1-->|hello world|B1
A11--"hello world<br>另种方式"-->B11
ca11==>|hello world|ca21
ca1=="hello world<br>另种方式"==>ca2
xa-.->|I like the world|xa1
xa11-."I like the world<br>另种方式".->xa111
flowchart LR
a1---|"hello world, <br>我喜欢"|b1
c1===|hello world|c2
x1-.-|I like the world|x2
a1---|"hello world, <br>我喜欢"|b1
c1===|hello world|c2
x1-.-|I like the world|x2
备注,连接的上文字不能是标点符号。所以连接上的文字要精炼。但如果确实需要特殊字符则可以放到英文双引号
" "中。
其他箭头形状
flowchart LR
A --o B --x C
A --o B --x C
flowchart LR
A o--o B x--x C
A o--o B x--x C
连接长度
流程图中的每个节点最终都会根据其连接到的节点分配到渲染图中的等级,即垂直或水平级别(取决于流程图方向)。 默认情况下,连接可以跨越任意数量的等级,但可以通过在连接定义中添加额外的破折号来要求任何连接比其他连接更长。
flowchart TB
A[开始]-->A1{想去旅游吗}
A1-->|想|B{有新冠疫情吗}
B-->|No|可以去
B-->|Yes|不能去
A1----->|不想|结束
A[开始]-->A1{想去旅游吗}
A1-->|想|B{有新冠疫情吗}
B-->|No|可以去 -->E
B-->|Yes|不能去 -->E
A1----->|不想|E[结束]
特殊字符
特殊字符比如,()[]*等等无法被渲染,可以将文本放在英文双引号""内。 如下例所示:
flowchart LR
A["我是特殊字符,比如:<br>[]{}*`:=->"]
A["我是特殊字符,比如:<br>[]{}*`:=->"]
转义字符
flowchart LR
A["我是特殊字符,比如:#9829;、""]
A["我是特殊字符,比如:#9829;、""]
给出的数字是以 10 为基数,因此 # 可以编码为 #35;,#9829表示心形。 还支持使用 HTML 字符名称,比如双引号可以用"表示。
子图(subgraph)
flowchart LR
subgraph R[需求]
%%备注表示子图方向的命令不起作用: directive LR
需求调研 --> 需求分析 --> 需求说明书
end
subgraph C[编码和调试]
需求理解-->编码-->调试
end
subgraph D[上线]
数据库初始化--> 软件部署-->应用启动
end
R==>C==>D
subgraph R[需求]
%%备注表示子图方向的命令不起作用: directive LR
需求调研 --> 需求分析 --> 需求说明书
end
subgraph C[编码和调试]
需求理解-->编码-->调试
end
subgraph D[上线]
数据库初始化--> 软件部署-->应用启动
end
R==>C==>D
注解
如果需要注解则可以使用%%
flowchart RL
%%从左到右的普通流程图
A-->B
%%从左到右的普通流程图
A-->B
markdown mermaid流程图的更多相关文章
- Markdown Mermaid
Mermaid 是一个用于画流程图.状态图.时序图.甘特图的库,使用 JS 进行本地渲染,广泛集成于许多 Markdown 编辑器中. 之前用过 PlantUML,但是发现这个东西的实现原理是生成 U ...
- Hexo引入Mermaid流程图和MathJax数学公式
近来用Markdown写文章,越来越不喜欢插入图片了,一切能用语法解决的问题坚决不放图,原因有二: 如果把流程图和数学公式都以图片方式放到文章内,当部署到Github上后,访问博客时图片加载实在太慢, ...
- markdown的流程图实现和代码语法着色
用flowchart为markdown添加流程图 举个例子如下,根据这个例子大家就能看懂我到底是怎么实现的 <!DOCTYPE html> <html> <head> ...
- MarkDown和流程图诠释你的代码
写在前面:首先感谢导师-猴哥对我的认可(求多分享点编程经验.工具.多开课),学习编程是一个痛苦和快乐的过程,希望大家共勉 本文介绍MarkDown的基本语法.使用MarkDown画简单的流程图.使用X ...
- VS Code实现markdown画流程图
安装最新的vscode编辑器,原生支持markdown语法.不会markdow的人可以去好好学下,写文档神器!!! 1.安装Markdown Preview Enhanced插件 2.本地新建test ...
- markdown的流程图、时序图、甘特图画法
https://www.jianshu.com/p/a9ff5a9cdb25 Markdown里面的序列图 https://shd101wyy.github.io/markdown-preview-e ...
- markdown ——flow流程图
一个纯文本的语法怎么画图? 将流程图代码包含在```folw和`````之间即可 例子 st=>start: Start op=>operation: Your Operation sub ...
- markdown mermaid序列图
序列图(时序图) 序列图是一种交互图,它显示了进程如何相互操作以及按什么顺序操作. sequenceDiagram participant l as 大灰狼 participant y as 小羊 l ...
- markdown mermaid状态图
状态图 状态图是一种用于计算机科学和相关领域描述系统行为的图.状态图要求描述的系统由有限数量的状态组成. 语法: stateDiagram-v2 [*] --> Still Still --&g ...
随机推荐
- 12.16 Java继承
首先 :继承,指一个对象直接使用另一对象的属性和方法. 继承的格式: public class 子类名 entends 父类名{} /* 表示前面的子类继承父类 */ 例:public class ...
- CF999A Mishka and Contest 题解
Content 能力值为 \(k\) 的小 M 参加一次考试,考试一共有 \(n\) 道题目,每道题目的难度为 \(a_i\).小 M 会选择两头中的一道难度不超过他的能力值题目去做,每做完一道,这道 ...
- 阿里云ilogtail收集自建Kubernetes容器日志文件
背景 1,k8s属于自建. 2,需要收集应用服务容器里面指定目录的日志. 3,计划收集所有私有云php和nginx日志. 4,日志格式化处理. 思考 1,一个私有云一个Project,还是统一放入一个 ...
- Django的Form表单验证
Form(from django import forms) 简短理解:后端提供了一个类:from django import forms,继承此类定义子类.子类中定义和form表单中提交到name名 ...
- Spring学习(一)idea中创建第一个Spring项目
1.前言 Spring框架是一个开放源代码的J2EE应用程序框架,由Rod Johnson发起,是针对bean的生命周期进行管理的轻量级容器(lightweight container). Sprin ...
- 关于Spring MVC的问题
一.SpringMVC的流程是什么? 1. 用户发送请求至前端控制器DispatcherServlet: 2. DispatcherServlet收到请求后,调用HandlerMapping处理器映射 ...
- 【论文笔记】 Popularity Bias in Dynamic Recommendation
Popularity Bias in Dynamic Recommendation Authors: Ziwei Zhu, Yun He, Xing Zhao, James Caverlee KDD' ...
- cmake全面教程
1. 官网教程 2. 中文教程 3. Modern CMake
- windows10使用VS(VC++)创建c++多进程命名管道通信
代码可以在 这里 下载 代码主要涉及到: 管道通信 多线程(含临界区) 多进程通信 创建的子进程独立运行 更新日志: 04-12-2020 1. 去除自定义函数返回值,改为int作为函数返回值并增加相 ...
- 【LeetCode】398. Random Pick Index 解题报告(Python & C++)
作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 每次遍历索引 字典保存索引 蓄水池抽样 日期 题目地 ...