LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

[点晴永久免费OA]WEB浏览器中用mermaid.js纯JS画甘特图

admin
2023年4月15日 10:45 本文热度 1871

今天简单总结一下 mermaid 的甘特图(gantt chart)语法, 因为昨天感觉mermaid 官网的 gantt 文档[1] 只给了几个例子 不太适合上手.

mermaid.js

mermaid.js[2]是一个用来在网页中生成图表的库. 使用简单的语法来描述图表, 通过 Javascript 渲染.

支持生成多种类型的图表, 例如流程图/时序图/甘特图等等.

Mermaid.js 的目标是让生成图表变得简单而且易于使用, 让用户能够更专注于图表的内容和信息的传递而不是图表的排版.

它的理念和 markdown/graphviz 一样, 用代码代替富文本(word/powerpoint/画图工具), 这样做的好处有:

  • 文件超小(只是文本文件), 打开和修改很方便
  • 生成的图片是 SVG, 不但美观还可以无损缩放
  • 方便版本管理(git)

之前我试过 mermaid 的流程图(flow chart), 感觉不如 graphviz 灵活(虽然语法更简洁). 但是 mermaid 被许多 markdown 编辑器支持, 而且覆盖了很多类型的图表, 所以相当值得一试.

有几个方式可以使用 mermaid:

  • mermaid.js 官方在线编辑器[3]
  • 笔记软件obsidian[4]默认支持 mermaid 语法的代码块嵌入 markdown 文件中
  • 使用VSCode 编辑器[5], 只需要安装mermaid VSCode 插件[6]就可以使用了

甘特图

Gantt chart (甘特图) 是一种用来展示项目进度和任务分配的图表.
它常常被用来展示在一个时间范围内任务的开始时间, 持续时间以及前置任务之间的关系.
Gantt chart 可以帮助团队成员更好地理解项目进度.并有效地协调任务之间的依赖关系.

=> 用来做时间线图表刚刚好

mermaid 甘特图语法

Mermaid.js 使用类似于 markdown 的语法来生成 Gantt 图. 可以划分不同章节, 每个章节包含若干任务信息.

关键字有:

  • title: 图表标题
  • section: 章节
    • 章节下包含若干任务, 每行一个任务信息
  • excludes: 排除若干日期, 可以是特定的日期(yyyy-mm-dd 格式), 也可以是星期几或"weekends"
    • 排除的日期会显示为灰色

描述任务起止时间

"任务" 在这里指一项事件或者工程, 表现为甘特图中的一条.

mermaid 每一行内容作为一个任务(或者事件)的描述, 大概语法为:

<task_name> : [<id>,] [<modifier(s)>,], <start_time>, <end_time|duration>

描述任务的开始和截止时间, 既可以都用实际的时间(start_time, end_time), 也可以用开始时间+进行长度(start_time, duration).
如果不给出开始时间, 默认从上一个任务结束开始算起.

虽然下面的例子都是以日期为单位, 其实它也支持小时/分钟的时间段, 比如可以用甘特图画一天的工作日志.

修饰符(modifier)

描述任务除了给出开始/结束的时间外, 还可以进行修饰修改其显示效果.

任务修饰符:

  • milestone: 里程碑
  • crit: 关键 -- 任务颜色变为红色
  • done: 已完成任务 -- 任务变为灰色
  • active: 进行中的任务
  • 另外这些关键字可以进行组合, 用逗号分隔.

任务依赖关系

由于甘特图用于展示项目进度和任务分配, 对任务之间的依赖关系也有支持.
可以在冒号后面给任务起一个 id, 然后用after关键字描述任务之间的依赖关系.

以房地产开发为例, 几个环节(拿地/设计/施工/装修/宣传/销售)的依赖关系可以这样搞定:

完整示例代码

gantt
 dateFormat  YYYY-MM-DD
 axisFormat %m/%d
 tickInterval 1week
 title       Mermaid甘特图实例
 excludes    weekends


 section 任务描述
   %% 开始/结束时间
   task1: 2022-01-01, 2022-01-09
   %% 开始时间+长度
   task2: 2022-01-11, 30d
   %% 只提供长度 默认开始时间为上一行任务的结束时间
   task3: 30d


 section 修饰符
   task1-无修饰 : 2022-01-01, 7d
   task2-已完成('done') : done, 2022-01-02, 10d
   task3-关键任务('crit') : crit, 2022-01-10, 10d
   task4-进行中('active) : active, 2022-01-20, 10d
   %% 里程碑 -- 注意里程碑也需要提供结束时间(可以设置duration=0d)
   task5-里程碑 : milestone, 2022-01-30, 0d
   %% 修饰符可以组合使用
   task6-组合(done+crit) : done, crit, 2022-01-15, 7d
   task6-组合(active+crit) : active, crit, 7d


 section 任务依赖
   %% 给任务起一个代号("nd"), 方便依赖时引用
   拿地: nd, 2022-01-05, 8d
   设计: sj, 2022-01-01, 14d
   %% 依赖多个任务时, 空格分开
   施工: sg, after nd sj, 30d
   装修: zx, after sg, 10d
   宣传: xc, after nd, 20d
   销售: after xc, 30d

参考资料

[1]

mermaid官网的gantt文档: https://mermaid.js.org/syntax/gantt.html

[2]

mermaid.js: https://mermaid.js.org/

[3]

mermaid.js官方在线编辑器: https://mermaid.live/

[4]

obsidian: https://obsidian.md/

[5]

VSCode编辑器: https://code.visualstudio.com/

[6]

mermaid VSCode插件: https://marketplace.visualstudio.com/items?itemName=bierner.markdown-mermaid


该文章在 2023/4/15 10:45:24 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2024 ClickSun All Rights Reserved