目录

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。

本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
星霜旅人2 分钟前
【MySQL】从零开始:掌握MySQL数据库的核心概念(四)
数据库·mysql
꧁༺朝花夕逝༻꧂2 分钟前
MySQL-查询语句
数据库·mysql
uhakadotcom7 分钟前
当待处理的日志到了TB级别,这些工具你不得不学起来...
算法·架构·github
excel12 分钟前
webpack 核心编译器 第二节
前端
拉不动的猪14 分钟前
electron的渲染进程与渲染进程之间的通信
前端·javascript·面试
冴羽19 分钟前
SvelteKit 最新中文文档教程(12)—— 高级路由
前端·javascript·svelte
LLM丶星1 小时前
CSS+JS 堆叠图片动态交互切换
前端·javascript·css
等什么君!1 小时前
element-plus 的简单应用
前端·javascript·vue.js
一点一木1 小时前
🚀 2025年03月 GitHub 十大热门项目排行榜 🔥
前端·人工智能·github
cooldream20091 小时前
内存型数据库深入解析:Memcache、Redis 与 Squid 的对比与应用
数据库·redis·memcached