Mermaid 教程

Mermaid 教程

Mermaid 介绍

Mermaid 是一个用于生成流程图、时序图、甘特图等图表的 JavaScript 库。它使用类似于 Markdown 的文本语法,使得创建图表变得简单直观。以下是一个简单的 Mermaid 教程,介绍如何使用 Mermaid 创建流程图、时序图和甘特图。

安装 Mermaid

可以通过以下方式在你的项目中安装 Mermaid:

bash 复制代码
npm install mermaid

或者直接在 HTML 文件中引入 Mermaid 的 CDN:

html 复制代码
<script src="https://cdn.jsdelivr.net/npm/mermaid@11"></script>

Mermaid教程实例

创建流程图

使用 Mermaid 创建流程图的语法类似于 Markdown,

Mermaid 的语法:

  • graph TD; 表示创建一个有向图,从上到下的方向。
  • 节点通过 --> 连接,表示流程的顺序。
  • 判断条件通过 -- 条件 --> 表示,条件的两边分别连接两个可能的步骤。
  • 方形节点表示流程步骤,圆形节点表示开始和结束。

如下所示:

复制代码
graph TD;
  A[开始] -->|条件1| B(流程步骤1);
  B -->|条件2| C(流程步骤2);
  C --> D{条件3};
  D -->|是| E(结束);
  D -->|否| F(流程步骤3);
  F --> E;

条件1 条件2 是 否 开始 流程步骤1 流程步骤2 条件3 结束 流程步骤3

上述代码创建了一个简单的流程图,其中包含开始、流程步骤、条件、判断和结束。

横向流程图
复制代码
graph LR
A[长方形] -- 链接 --> B((圆))
A --> C(圆角长方形)
B --> D{菱形}
C --> D

链接 长方形 圆 圆角长方形 菱形

创建时序图

时序图用于展示事件在时间轴上的顺序。以下是一个简单的时序图示例:

复制代码
sequenceDiagram
  participant A as Alice
  participant B as Bob
  A->>B: 消息1
  B->>A: 消息2

Alice Bob 消息1 消息2 Alice Bob

创建甘特图

甘特图用于展示任务的时间安排。以下是一个简单的甘特图示例:

复制代码
gantt
  title 项目计划
  section 任务1
    完成任务1 :a1, 2024-01-11, 30d
    任务2 :after a1 , 20d
  section 任务2
    任务3 : 12d
    完成任务4 : 20d

2024-01-14 2024-01-21 2024-01-28 2024-02-04 2024-02-11 2024-02-18 2024-02-25 2024-03-03 2024-03-10 2024-03-17 2024-03-24 2024-03-31 完成任务1 任务2 任务3 完成任务4 任务1 任务2 项目计划

这个示例中,你可以定义项目计划中的不同任务,包括开始时间、持续时间等信息。

类图

Mermaid 也支持创建类图。以下是一个简单的 Mermaid 类图的示例:

复制代码
classDiagram
  class Animal {
    +name: string
    +makeSound(): void
  }

  class Dog {
    +breed: string
    +bark(): void
  }

  class Cat {
    +color: string
    +meow(): void
  }

  Animal <|-- Dog
  Animal <|-- Cat

Animal +name: string +makeSound() Dog +breed: string +bark() Cat +color: string +meow()

git 图

Mermaid 支持创建 Git 图,用于展示 Git 分支、合并、提交等操作。以下是一个简单的 Mermaid Git 图的示例:

复制代码
    gitGraph
       commit
       commit
       branch develop
       commit
       commit
       commit
       checkout main
       commit
       commit

journey 图

下面是一个简单的 Mermaid Journey 图的示例,表示一个过程的流程:

复制代码
journey
    title My Journey
    section Getting Started
      Make tea: 5: Me
      Go upstairs: 3: Me
      Do work: 1: Me, Cat
    section Additional Steps
      Go downstairs: 5: Me
      Sit down: 5: Me

Cat Me Step 1 Getting Started Getting Started Step 1 A --> B A --> B Me Make tea Make tea Me Go upstairs Go upstairs Me Cat Do work Do work Additional Steps Additional Steps Me Go downstairs Go downstairs Me Sit down Sit down Conclusion Conclusion F --> G F --> G My Journey

在这个示例中:

  • journey 表示 Journey 图的开始。
  • title 用于设置 Journey 的标题。
  • section 定义了 Journey 的不同阶段。
  • A(Start) --> B(Step 1) 表示 Journey 从 A 到 B 的步骤,带有标签 "Step 1"。

你可以根据需要定制标签、步骤和整体 Journey 结构。

以上是一个简单的 Mermaid 教程,希望能够帮助使用 Mermaid 创建流程图、时序图和甘特图。更多详细信息和高级用法,请参考 Mermaid 的官方文档:Mermaid Documentation。

相关推荐
4***14902 小时前
前端构建工具多页面配置,Webpack与Vite
前端·webpack·node.js
网络点点滴2 小时前
标签的ref属性
前端·javascript·vue.js
倔强的石头_2 小时前
openGauss实战:Python开发与AI向量数据库应用
数据库
马克学长2 小时前
SSM快递代收系统00pay(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
天若有情6733 小时前
前端 vs 后端:入行软件行业,我该如何选择?哪个更“简单”?
前端·后端·软件开发·职业·就业·选择
小画家~3 小时前
第二十八:golang Time.time 时间格式返回定义结构体
java·前端·golang
谅望者3 小时前
数据分析笔记07:Python编程语言介绍
大数据·数据库·笔记·python·数据挖掘·数据分析
面向星辰3 小时前
sql基本增删改查语句汇总
数据库·sql·mybatis
Cobyte3 小时前
17. Vue3 业务组件库按需加载的实现原理
前端·javascript·vue.js
粥里有勺糖4 小时前
视野修炼-技术周刊第127期 | Valdi
前端·javascript·github