类Markdown实时绘图编辑器mermaid-live-editor

本文介绍了Mermaid,一种基于文本的图表描述语言,以及其配套的MermaidLiveEditor。文章详细说明了如何在群晖上通过Docker安装和配置MermaidLiveEditor,以及其提供的实时预览、分享和命令行安装选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在这里插入图片描述

什么是 Mermaid ?

Mermaid 是一个基于文本的图表描述语言,它允许你使用简洁的语法来描述各种不同类型的图表和图示,例如流程图、时序图、甘特图等。

在这里插入图片描述

什么是 mermaid-live-editor ?

mermaid-live-editor 是一个基于 Javascript 的在线编辑器,提供了一个用户友好的界面,让你可以输入和编辑 Mermaid 代码,并实时预览生成的图表。你可以在编辑器中进行调整和修改,以获得你想要的图表效果。此外,它还提供了分享功能,让你可以将编辑好的图表分享给他人,或者将生成的图表代码导出到其他文档或应用程序中使用。

目前软件的功能主要包括:

  • 实时编辑和预览流程图、序列图、甘特图等;
  • 将结果保存为 svg 等;
  • 获取图表查看器的链接,以便您可以与其他人共享;
  • 获取编辑图表的链接,以便其他人可以调整它并发回新链接;

官方提供了在线的 Mermaid Live Editor 供大家体验,地址 :https://mermaid.live

在这里插入图片描述

安装

在群晖上以 Docker 方式安装。

镜像下载

官方没有在 docker hub 上发布镜像,而是发布在 ghcr.io

在这里插入图片描述

SSH 客户端登录到群晖后,执行下面的命令

# 拉取镜像
docker pull ghcr.io/mermaid-js/mermaid-live-editor:latest

如果没有科学上网,很可能会拉不动,可以试试 docker 代理网站:https://dockerproxy.com/,但是会多几个步骤

# 如果拉不动的话加个代理
docker pull ghcr.dockerproxy.com/mermaid-js/mermaid-live-editor:latest

# 重命名镜像(如果是通过代理下载的)
docker tag ghcr.dockerproxy.com/mermaid-js/mermaid-live-editor:latest ghcr.io/mermaid-js/mermaid-live-editor:latest

# 删除代理镜像(如果是通过代理下载的)
docker tag ghcr.dockerproxy.com/mermaid-js/mermaid-live-editor:latest ghcr.io/mermaid-js/mermaid-live-editor:latest

下载完成后,可以在 映像 中找到

在这里插入图片描述

命令行安装

如果你熟悉命令行,可能用 docker cli 更快捷

# 新建文件夹 mermaid 
mkdir -p /volume1/docker/mermaid

# 进入 mermaid 目录
cd /volume1/docker/mermaid

# 运行容器
docker run -d \
   --restart unless-stopped \
   --name mermaid-live-editor \
   -p 8830:8080 \
   ghcr.io/mermaid-js/mermaid-live-editor:latest

也可以用 docker-compose 安装,将下面的内容保存为 docker-compose.yml 文件

version: '3'

services:
  mermaid:
    image: ghcr.io/mermaid-js/mermaid-live-editor:latest
    container_name: mermaid-live-editor
    restart: unless-stopped
    ports:
      - 8830:8080

然后执行下面的命令

# 新建文件夹 mermaid 
mkdir -p /volume1/docker/mermaid

# 进入 mermaid 目录
cd /volume1/docker/mermaid

# 将 docker-compose.yml 放入当前目录

# 一键启动
docker-compose up -d

运行

在浏览器中输入 http://群晖IP:8830 就能看到主界面

在这里插入图片描述

Sample Diagrams 中有一些示例,例如甘特图、脑图等

在这里插入图片描述

History 是历史记录

在这里插入图片描述

Actions 可以将 Diagram 分享或者转为图片

在这里插入图片描述

参考文档

mermaid-js/mermaid: Generation of diagrams like flowcharts or sequence diagrams from text in a similar manner as markdown
地址:https://github.com/mermaid-js/mermaid

mermaid-js/mermaid-live-editor: Edit, preview and share mermaid charts/diagrams. New implementation of the live editor.
地址:https://github.com/mermaid-js/mermaid-live-editor

Mermaid | Diagramming and charting tool
地址:https://mermaid.js.org/

<think>嗯,用户问我是否了解Mermaid语法,需要我用中文介绍。首先,我需要确认自己掌握的信息是否正确,然后组织语言,让用户容易理解。Mermaid是一个基于JavaScript的图表生成工具,可以用文本代码创建图表,比如流程图、序列图、甘特图等。用户可能想了解它的基本概念、常用图表型、语法示例以及优点和使用场景。 用户可能是开发者、技术写作者或者项目管理人员,他们可能需要在文档中快速生成图表,或者希望版本控制友好。需要强调Mermaid的文本化优势,比如易于维护、协作,以及集成到Markdown中的便利性。 可能需要分几个部分介绍:基本概念、常用图表型及示例、优点、使用场景。要确保每个例子准确,比如流程图的语法是否正确,箭头方向是否正确。还要注意术语的一致性,比如“节点”、“连接线”等。 需要检查是否有常见的误区,比如是否需要安装额外软件,实际上很多平台如GitHub、GitLab已经支持Mermaid,直接嵌入Markdown即可。可能用户不熟悉如何开始使用,可以建议他们查看官方文档或在线编辑器练习。 另外,用户可能想知道Mermaid与其他工具(如PlantUML)的区别,但问题中没有提到,可能暂时不需要展开。但可以提到其简洁性和集成性作为优点。 最后,总结Mermaid的实用性,鼓励用户尝试,提供简单的示例让他们可以快速上手。确保语言口语化,避免技术术语过多,让不同层次的用户都能理解。</think>是的,我了解 **Mermaid 语法**,它是一种基于文本的图表生成工具,可以通过简单的代码快速绘制多种型的图表(如流程图、时序图、甘特图等),并直接嵌入到 Markdown 文档或支持 Mermaid 的平台上。以下是它的核心特点和使用场景: --- ### **1. 核心特点** - **文本化图表**:用代码代替拖拽绘图,便于版本控制和协作。 - **跨平台支持**:兼容 GitHub、GitLab、Notion、Obsidian 等平台的 Markdown- **轻量简洁**:无需复杂工具,学习成本低。 --- ### **2. 常用图表型 & 语法示例** #### **流程图(Flowchart)** ```mermaid graph TD A[起床] --> B{是否周末?} B -->|是| C[睡懒觉] B -->|否| D[去上班] D --> E[下班] ``` #### **时序图(Sequence Diagram)** ```mermaid sequenceDiagram Alice->>Bob: 你好吗? Bob->>Alice: 我很好! ``` #### **图(Class Diagram)** ```mermaid classDiagram class Animal { +String name +void eat() } class Dog { +void bark() } Animal <|-- Dog ``` #### **甘特图(Gantt Chart)** ```mermaid gantt title 项目计划 section 阶段A 任务1 :a1, 2023-10-01, 7d 任务2 :after a1, 3d ``` --- ### **3. 优点** - **高效维护**:修改代码即可更新图表,无需重新绘图- **开发者友好**:与代码仓库(如 Git)无缝集成。 - **开源免费**:社区活跃,持续更新。 --- ### **4. 如何使用?** 1. 在支持 Mermaid 的平台(如 GitHub)的 Markdown 中,用 ````mermaid` 包裹代码块。 2. 使用在线编辑器(如 [Mermaid Live Editor](https://mermaid.live/))实时预览。 3. 查看[官方文档](https://mermaid.js.org/)学习更多图表型(如饼图、状态图等)。 如果需要具体某图表的详细教程,可以告诉我,我会进一步解释! 😊
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杨浦老苏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值