Markdown 之 UML图的实用画法

2024-02-14 13:32
文章标签 实用 uml markdown 画法

本文主要是介绍Markdown 之 UML图的实用画法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

版权声明:本文为 小异常 原创文章,非商用自由转载-保持署名-注明出处,谢谢!
本文网址:https://blog.csdn.net/sun8112133/article/details/79891479

  UML:称为统一建模语言或标准建模语言。它是一种可视化的面向对象建模语言,是一种用来对真实世界物理进行建模的标准标记,用图形方式表现典型的面向对象系统的整个结构。
  
  平常我们画 UML图 时,需要借助像 StarUMLVisio 等这一类的工具软件,其实我们完全可以借助 Markdown 就可以快速的画出漂亮的UML图了。
  
  本篇以实用为主,不对画图中的细节作过多的描述,主要讲解UML图中最常用的序列图流程图
  (本人使用Typora,因为它具有实时渲染可见与编辑的特点)

  新手可以点击这里快速学习MarkDown。




一、序列图(关键字:sequence)

1、先来个小例子
``` sequence
title: 三个臭皮匠的故事
participant 小王
participant 小李
participant 小异常note left of 小王: 我是小王
note over 小李: 我是小李
note right of 小异常: 大家好!\n我是小异常小王->小王: 小王想:今天要去见两个好朋友咯~
小王->小李: 嘿,小李好久不见啊~ 
小李-->>小王: 是啊
小李->小异常: 小异常,你好啊
小异常-->小王: 哈,小王!\n最近身体怎么样了?
小王->>小异常: 还可以吧
```

 效果如下:

序列图之三个臭皮匠的故事

2、关键字
  1)title

  表示该序列图中的标题。

  2)participant

  表示该序列图中的对象。

  3)note

  表示该序列图中的部分说明。关于note以下三种关键字:
    * left of:表示在当前对象的左侧。
    * right of:表示在当前对象的右侧。
    * over:表示覆盖在当前对象的上方。

3、箭头
  1)->:实线实箭头
  2)–>:虚线实箭头
  3)->>:实线虚箭头
  4)–>>:虚线虚箭头
4、换行

  如果当前行中的文字过多想要换行,可以使用 \n 进行转义换行,效果如以上例子。


二、流程图(关键字:flow)

1、再来个小例子
```flow
sta=>start: 开始
e=>end: 结束
op=>operation: 操作(处理块)
sub=>subroutine: 子程序
cond=>condition: 是或者不是(条件判断)?
cond2=>condition: 第二个判断(条件判断)?
io=>inputoutput: 输出sta->op->cond
cond(yes)->e
cond(no)->cond2
cond2(yes,right)->sub(left)-op
cond2(no)->io(lef)->e
```

 效果如下:

流程图

2、关键字
  1)start, end

  表示该流程图中的开始与结束。

  2)operation

  表示该流程图中的处理块。

  3)subroutine

  表示该流程图中的子程序块。

  4)condition

  表示该流程图中的条件判断。

  5)inputoutput

  表示该流程图中的输入输出。

  6)right, left

  表示该流程图中当前模块下一个箭头的指向(默认箭头指向下方)。

  7)yes, no

  表示该流程图中条件判断的分支(默认yes箭头向下no箭头向右;yes与no可以和right同时使用;yes箭头向右时,no箭头向下)

3、各模块之间的联系
  1)形式:

 基本形式:

模块标识=>模块关键字: 模块模块名称

 连接定义:

模块标识1->模块标识2
模块标识1->模块标识2->模块标识3
... ...
  2)说明:

  通过模块与连接定义,可以组成一个完整的流程图。
  在模块定义中,模块标识与模块名称可以自定义,模块关键字不可以自定义!

3、注意事项
  1)在进行连接的时候,可以通过right, left确定箭头的指向;
  2)使用条件判断的连接时需要结合yes和no进行;
  3)在连接各模块之间不能有空格,在模块标识关键字时也不能有空格。

这篇关于Markdown 之 UML图的实用画法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/708625

相关文章

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式

《C#实现将Office文档(Word/Excel/PDF/PPT)转为Markdown格式》Markdown凭借简洁的语法、优良的可读性,以及对版本控制系统的高度兼容性,逐渐成为最受欢迎的文档格式... 目录为什么要将文档转换为 Markdown 格式使用工具将 Word 文档转换为 Markdown(.

MySQL 添加索引5种方式示例详解(实用sql代码)

《MySQL添加索引5种方式示例详解(实用sql代码)》在MySQL数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中,下面给大家分享MySQL添加索引5种方式示例详解(实用sql代码),... 在mysql数据库中添加索引可以帮助提高查询性能,尤其是在数据量大的表中。索引可以在创建表时定义,也可

使用Python实现网页表格转换为markdown

《使用Python实现网页表格转换为markdown》在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,本文将使用Python编写一个网页表格转Markdown工具,需... 在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,以便在文档、邮件或

JDK9到JDK21中值得掌握的29个实用特性分享

《JDK9到JDK21中值得掌握的29个实用特性分享》Java的演进节奏从JDK9开始显著加快,每半年一个新版本的发布节奏为Java带来了大量的新特性,本文整理了29个JDK9到JDK21中值得掌握的... 目录JDK 9 模块化与API增强1. 集合工厂方法:一行代码创建不可变集合2. 私有接口方法:接口

9个SpringBoot中的自带实用过滤器使用详解

《9个SpringBoot中的自带实用过滤器使用详解》在SpringBoot应用中,过滤器(Filter)是处理HTTP请求和响应的重要组件,SpringBoot自带了许多实用的过滤器,如字符编码,跨... 目录1. CharacterEncodingFilter - 字符编码过滤器功能和配置手动配置示例2

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

使用Python开发一个带EPUB转换功能的Markdown编辑器

《使用Python开发一个带EPUB转换功能的Markdown编辑器》Markdown因其简单易用和强大的格式支持,成为了写作者、开发者及内容创作者的首选格式,本文将通过Python开发一个Markd... 目录应用概览代码结构与核心组件1. 初始化与布局 (__init__)2. 工具栏 (setup_t

利用Python快速搭建Markdown笔记发布系统

《利用Python快速搭建Markdown笔记发布系统》这篇文章主要为大家详细介绍了使用Python生态的成熟工具,在30分钟内搭建一个支持Markdown渲染、分类标签、全文搜索的私有化知识发布系统... 目录引言:为什么要自建知识博客一、技术选型:极简主义开发栈二、系统架构设计三、核心代码实现(分步解析