【JsPlumb】基于JsPlumb设计的Web拓扑图编辑器
Easy editor
项目介绍
Easy Editor
是基于 VUE+ElementUI+JsPlumb 的拓扑编辑器,通过该编辑器你可以实现拓扑图绘制,拓扑图的修改等功能
节点拖拽功能实现流程
通过 vuedraggable 插件来实现左侧菜单的拖拽,拖拽结束后回调 end 方法,根据鼠标所在的位置添加一个节点信息,使用 jsplumb 来管理该节点,设置该节点可拖拽、连线 并注册相关的事件。
效果图
功能
- 支持拖拽添加节点
- 鼠标移入到节点中显示 编辑、删除 操作
- 鼠标单击线可进行设置条件,双击可进行连线删除
- 支持预设的流程图案例切换展示
- 支持画布拖拽,控制画布网格背景
- 支持放大缩小
- 支持一键生成流程图图片
- 支持数据文件导入(目前只支持yaml文件和json文件)
- 支持显示节点内部详情
- 支持节点间回环连接,但不支持节点线连接自己
操作说明
- 左侧菜单子节点可以拖拽,将其拖拽到右侧画板中松开鼠标即可添加一个节点
- 鼠标点击画板中的节点上,画布右侧出现可编辑的节点详情表单,上方工具栏删除按钮功能开启,点击对应的图标可进行删除、编辑操作
- 节点分为 3 部分,节点图标在左侧,文字在中间,状态图标在右侧,鼠标从节点图标上可以拖拽出连线,可以连接其他节点,拖动图标意外位置可以改变节点在页面的位置
使用说明
- 【自定义节点】:左侧的节点名称以及图标可以自定义,在 node_menu.vue 页面 menuList 变量中
- 【节点添加】:左侧的菜单栏展开时,子节点可以拖拽到右侧画布中即可添加
- 【节点修改】:鼠标移动到画布中节点上,画布右侧显示用户【修改】节点的表单
- 【连线添加】:将鼠标从画布节点的左侧图标上拖动时可以拖拽出连线,然后将鼠标移动到其他节点上即可连接
- 【连线删除】:双击画布中节点之间的连线,可以进行连线删除
流程图数据格式
{"name": "流程C","nodeList": [{"id": "nodeA","name": "流程B-节点A","type": "task","left": "18px","top": "223px","ico": "el-icon-user-solid","state": "success"},{"id": "nodeB","type": "task","name": "流程B-节点B","left": "351px","top": "96px","ico": "el-icon-goods","state": "error"},{"id": "nodeC","name": "流程B-节点C","type": "task","left": "354px","top": "351px","ico": "el-icon-present","state": "warning"},{"id": "nodeD","name": "流程B-节点D","type": "task","left": "723px","top": "215px","ico": "el-icon-present","state": "running"}],"lineList": [{"from": "nodeA","to": "nodeB","label": "条件AB","connector": "Bezier","paintStyle": { "strokeWidth": 2, "stroke": "#1879FF" }},{"from": "nodeB","to": "nodeC","label": "条件B""connector": "Bezier","paintStyle": { "strokeWidth": 2, "stroke": "#1879FF" }}]
}
data 参数说明
参数 | 描述 |
---|---|
name | 流程图名称 |
nodeList 参数说明
参数 | 描述 | 可选值 |
---|---|---|
id | 标识唯一的节点 | |
name | 节点名称 | |
type | 节点类型 | |
left | 节点在页面上的 X 坐标 | |
top | 节点在页面上的 Y 坐标 | |
ico | 节点显示的图标 | element上的icon名 |
state | 节点状态 | success、error、warning、running |
lineList 参数说明
参数 | 描述 | 可选值 |
---|---|---|
from | 连线的起始节点的 ID | |
to | 连线的终点节点 ID | |
label | 连线说明 | |
connector | 连线风格 | StateMachine、Flowchart,Bezier、Straight(默认为Flowchart) |
paintStyle | 连线样式 | 如:{ “strokeWidth”: 2, “stroke”: “#1879FF” } strokeWidth为连线宽度,stroke为连线颜色 |
自定义节点列表数据格式
自定义的节点列表数据写在node_menu.vue文件中的menuList变量中
menuList: [{id: "1",type: "group",name: "接口节点",ico: "el-icon-video-play",children: [{id: "11",level: "1-1",type: "task1",name: "数据接入",ico: "el-icon-time",state: "success",// 自定义覆盖样式style: {"backgroundColor": "red"}}, {id: "12",level: "1-2",type: "task2",name: "接口调用",ico: "el-icon-odometer",state: "success",// 自定义覆盖样式style: {}}]},{id: "2",type: "group",name: "工具节点",ico: "el-icon-video-pause",children: [{id: "21",level: "2-1",type: "end",name: "流程结束",ico: "el-icon-caret-right",state: "success",// 自定义覆盖样式style: {}}, {id: "22",level: "2-2",type: "over",name: "数据重置",ico: "el-icon-shopping-cart-full",state: "success",// 自定义覆盖样式style: {}}]}]
menuList参数说明
参数 | 描述 | 可选值 |
---|---|---|
id | 节点分组的id名 | |
type | 类别 | group |
name | 节点分组的名称 | |
ico | 节点分组的图标 | element-ui中的icon名或iconfont上的名称 |
children | 节点分组下的所有节点 |
children参数说明
参数 | 描述 | 可选值 |
---|---|---|
id | 节点分组的id名 | |
level | 节点层级 | |
type | 节点类别 | 注意:这里的type值需要是唯一的,否则无法正常新增节点元素 |
name | 节点分组的图标 | element-ui中的icon名或iconfont上的名称 |
state | 节点状态 | success、error、warning、running |
style | 自定义覆盖样式 |
流程图绘制实现流程
使用方式:
一、以独立项目使用
# 下载工程
git clone https://gitee.com/save_money/Easy-Editor.git# 安装依赖包
npm install# 启动
npm run dev# 访问地址http://localhost:8080
Gitee
https://gitee.com/save_money/Easy-Editor
参考资料
名称 | 地址 | 说明 |
---|---|---|
jsplumb | http://jsplumb.github.io/jsplumb/connections.html#sourcefilter | 官网API文档 |
vue-codemirror | https://github.surmon.me/vue-codemirror/ | 代码编辑器 |
vuedraggable | <https://sortablejs.github.io/Vue.Draggable/#/simple> | 节点拖拽 |
vue-json-viewer | https://github.com/chenfengjw163/vue-json-viewer | json数据查看 |
domtoimage | https://github.com/tsayen/dom-to-image#readme | web截图工具 |
js-yaml | https://github.com/nodeca/js-yaml | yaml数据转换 |
【JsPlumb】基于JsPlumb设计的Web拓扑图编辑器相关推荐
- 基于MVC设计(Java Web程序)----图书馆系统
文章目录 基于MVC设计----图书馆系统 整体项目运行截图 登录设计(MVC设计模式) 登录功能源代码 总结 基于MVC设计----图书馆系统 这一学期学习了JavaWeb开发, 课程结束时老师给的 ...
- jsplumb设置锚点_拓扑图编辑器-jsplumb基本配置
默认配置 jsPlumb的配置项有很多,如果不主动设置,jsPlumb就使用默认配置. 建议不要修改默认的配置,而是使用自定义的方式. Anchor:锚点,端点连接的位置 Anchors:多个锚点,[ ...
- jsplumb拖线_基于 jsPlumb 的流程图编辑器的实现 (二,连接线的操作)
连接线支持单击选中,backspace 和 delete 可删除:双击可以为连接线添加 label. 完整代码: /** * 单击删除连线 * */ clickLine:function(){ var ...
- jsplumb设置锚点_记录一次基于jsPlumb流程图编辑器的开发过程
前言 接到项目需求后,发现没有做过相关项目,盘算着拖拽倒是没有问题,但是控件的连线好像挺复杂,所以先开始了一番搜索,希望有合适的轮子那最好不过了.看了这篇对比文章:超级好用的流程图js框架,也看了一个 ...
- 基于 jsPlumb 的流程图编辑器的实现 (一,节点的操作)
写在最前,就是第一次写博客,不免感慨,可以直接跳过 O(∩_∩)O 这是自己第一次写博客,经验不充分,如果觉得代码不详细,文章底部有源码地址,欢迎大家下载.基本的功能都实现了,测试有限,如果发现问题, ...
- 【技术博客】基于JsPlumb和JQuery-UI的流程图的保存和再生成
开发组在开发过程中,都不可避免地遇到了一些困难或问题,但都最终想出办法克服了.我们认为这样的经验是有必要记录下来的,因此就有了[技术博客]. 基于JsPlumb和JQuery-UI的流程图的保存和再生 ...
- (转)基于MVC4+EasyUI的Web开发框架形成之旅--MVC控制器的设计
http://www.cnblogs.com/wuhuacong/p/3284628.html 自从上篇<基于MVC4+EasyUI的Web开发框架形成之旅--总体介绍>总体性的概括,得到 ...
- asp毕业设计——基于asp+sqlserver的WEB社区论坛设计与实现(毕业论文+程序源码)——社区论坛
基于asp+sqlserver的WEB社区论坛设计与实现(毕业论文+程序源码) 大家好,今天给大家介绍基于asp+sqlserver的WEB社区论坛设计与实现,文章末尾附有本毕业设计的论文和源码下载地 ...
- 一文看懂web组态编辑器web可视化组件
关键字: web组态编辑器集成,web组态页面集成,web可视化组件,web SCADA前端和后端,web可视化编辑器 web组态编辑器web图形可视化软件 web可视化编辑器,又称WEB组态可视化软 ...
最新文章
- Node.js中的express框架,修改内容后自动更新(免重启),express热更新
- python简单代码加法-Python tkinter实现简单加法计算器代码实例
- .NET Core微服务之基于Consul实现服务治理(续)
- Vector反向迭代器使用
- mpstat 命令查看所有CPU核信息
- kickstart文件配置与使用
- Linux gdb调试器
- AtCoder AGC029E Wandering TKHS
- 在Spring中使用JMS
- 怎样从frm ibd恢复mysql_怎样从frm,ibd恢复MYSQL
- MapTask、ReduceTask并行度决定机制
- 阿里技术专家:进击的 Java ,云原生时代的蜕变
- Num48 boss---02(pdm翻转,持久表现抽取,用户登退,消息提示,修密,自定义拦截器)...
- 常用的正则表达式,妈妈再也不用担心我不会写正则表达式了
- 【vn.py】源码解析之 Dual Thrust 策略
- ubuntu安装anaconda3报错
- php 处理eml,PHP 解析Maildir 邮件格式(eml文件)
- mysql分组查询学生平均年龄_那些年我们一起做过的[分组查询]_MySQL
- 总结篇:消息中间件MQ的学习境界和路线
- 基于Python的数据结构实验——顺序栈与链栈建立与操作(附详细代码和注释)
热门文章
- 智慧建筑的几个常见误区
- 面试/笔试第一弹 —— 计算机网络面试问题集锦【转】
- MIT诺奖大牛2万字雄文:记忆的本质
- gcc compile : assignment of read-only location '*p'
- 基于DANN的图像分类任务迁移学习
- 北京时间与UTC时间转换
- 取本机IP地址和网卡号
- 【每日新闻】2019年大数据10大发展趋势出炉!
- 【阅读笔记】针对PyTorch提高神经网络训练速度的方法—《Here are 17 ways of making PyTorch training faster – what did I miss?》
- html5知识点:超文本标记语言编程