vue项目引入bpmn做一款可以拖拽 输入的审核流程图

news/2024/5/18 23:53:40 标签: vue.js, 流程图, 前端

我们先引入依赖

npm install bpmn-js --save
npm install sass-loader sass --save

然后找到需要引用的组件参考代码如下


<template>
  <div class="containers">
    <div class="canvas" ref="canvas"></div>
  </div>
</template>

<script>
import BpmnModeler from 'bpmn-js/lib/Modeler' // 引入 bpmn-js
export default {
  data () {
    return {
      bpmnModeler: null
    }
  },
  methods: {
    createNewDiagram () {
      const bpmnXmlStr = `
      <?xml version="1.0" encoding="UTF-8"?>
        <bpmn2:definitions xmlns:bpmn2="http://www.omg.org/spec/BPMN/20100524/MODEL" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI" xmlns:dc="http://www.omg.org/spec/DD/20100524/DC" id="sample-diagram" targetNamespace="http://bpmn.io/schema/bpmn" xsi:schemaLocation="http://www.omg.org/spec/BPMN/20100524/MODEL BPMN20.xsd">
          <bpmn2:process id="process1567044459787" name="流程1567044459787">
            <bpmn2:documentation>描述</bpmn2:documentation>
            <bpmn2:startEvent id="StartEvent_1" name="开始"/>
          </bpmn2:process>
          <bpmndi:BPMNDiagram id="BPMNDiagram_1">
            <bpmndi:BPMNPlane id="BPMNPlane_1" bpmnElement="process1567044459787">
              <bpmndi:BPMNShape id="_BPMNShape_StartEvent_2" bpmnElement="StartEvent_1">
                <dc:Bounds x="184" y="64" width="36" height="36"/>
                <bpmndi:BPMNLabel>
                  <dc:Bounds x="191" y="40" width="22" height="14"/>
                </bpmndi:BPMNLabel>
              </bpmndi:BPMNShape>
            </bpmndi:BPMNPlane>
          </bpmndi:BPMNDiagram>
        <processType id="test"/></bpmn2:definitions>
      `
      // 将字符串转换成图显示出来
      this.bpmnModeler.importXML(bpmnXmlStr, (err) => {
        if (err) {
          console.error(err)
        }
      })
    }
  },
  mounted () {
    const canvas = this.$refs.canvas
    // 生成实例
    this.bpmnModeler = new BpmnModeler({
      container: canvas
    })
    this.createNewDiagram() // 新增流程定义
  }
}
</script>

<style lang="scss">
  /*左边工具栏以及编辑节点的样式*/
  @import '~bpmn-js/dist/assets/diagram-js.css';
  @import '~bpmn-js/dist/assets/bpmn-font/css/bpmn.css';
  @import '~bpmn-js/dist/assets/bpmn-font/css/bpmn-codes.css';
  @import '~bpmn-js/dist/assets/bpmn-font/css/bpmn-embedded.css';
  .containers{
    position: absolute;
    background-color: #ffffff;
    width: 100%;
    height: 100%;
    .canvas{
      width: 100%;
      height: 100%;
    }
    .bjs-powered-by {
      display: none;
    }
  }
</style>

这样我们就可以得到一个可拖拽和编写的审核流程图
在这里插入图片描述
确实还是比较好玩且使用的一款vue插件


http://www.niftyadmin.cn/n/1037348.html

相关文章

Seata源码分析——@GlobalTransactional

Seata源码分析——GlobalTransactional前言脑图Seata三大角色GlobalTransactional源码入口GlobalTransactionScanner初始化TM,RMwrapIfNecessary分支事务总结前言 研读Seata源码有一段时间了&#xff0c;打算出一系列关于源码的文章&#xff0c;旨在加强自己对Seata的理解&…

什么是java的流程控制语句,java又有哪些流程控制语句

程序中的任何一条语句都可以直接影响程序的执行顺序和执行结果 做为开发者 对语句一定要有明确的概念 java的流程控制语句分为三种 顺序结构 : 这种是最常见的 就是按顺序执行 从上往下走 也是程序基本的执行形式 就好像人生一直在向后发展 回不了头一样 分支结构 : 这也是像…

RocketMq存储设计——MappedFile

RocketMq存储设计——MappedFileMappedFile是什么优化源码MappedFile常量变量初始化写入数据flushcommitMappedFile RocketMq存储很多地方使用到了他&#xff0c;例如commit log(存储真正的消息数据)&#xff0c;consume queue&#xff08;真正的消息数据的索引&#xff09;&a…

java if判断语句

基本的语法就是 if(条件表达式){要执行的代码} 先看代码 public class HelloWorld {public static void main(String args[]) {int i 10;if(i > 5){System.out.println("条件成立");}} }执行结果如下 很显然 i 是 10 i大于5 的条件显然是成立的 所以if中的语句…

RocketMq存储设计——CommitLog

RocketMq存储设计——CommitLogCommitLog是什么文件格式刷盘线程异步刷盘同步组刷盘堆外内存刷到page cache总结CommitLog 是什么 commit log是RocketMQ真正存储消息的文件&#xff0c;文件存储依赖于mapped file ,mapped file queue 文件格式 4 //TOTALSIZE 4 //MAGICCODE …

java switch判断语句

switch语句相比于if 只能说各有优势 他们都有比较好的应用场景 而不像一些语句 可能后面学的才是用得到的 前面的就基本用不到 我们先来看看switch语句的基本用法 switch(要判断的变量){ case 值: 条件达到时执行的语句 break; default: 当上面的条件都没达到时执行的语句 bre…

RocketMq存储设计——Consume Queue

RocketMq存储设计——Consume QueueConsume Queue是什么格式consume queue的生成Consume Queue 是什么 consume queue是mq的消费索引文件&#xff0c;只要你知道consume queue offset就能快速定位到commit log offset&#xff0c;就能快速定位到一条消息。注意一个consume qu…

java for循环语句

相信大家都懂循环的概念 循环不止 就是一个典语 还有王者荣耀大小姐末日机甲的台词 “替你们准备好了死循环&#xff0c;立刻执行的那种” 循环语句简单说就是程序反复的做同一件事 但既然有死循环 那就有活的 编程中的循环都是有条件的 当条件达到时循环就是停止 如果没有条件…