当前位置: 首页 > news >正文

用通义灵码帮助实现校验bpmn.js当前画布上只能有一个开始节点的功能

最终代码:

     const elementRegistry = this.bpmnModeler.get('elementRegistry');// 获取所有元素const allElements = elementRegistry.getAll();// 过滤出开始节点const startEvents = allElements.filter(element => element.type === 'bpmn:StartEvent');// 校验开始节点的数量if (startEvents.length !== 1) {alert('画布上必须且只能有一个开始节点');return;}

实现过程:

我:bpmn.js如何实现校验当前画布上只能有一个开始节点

通义灵码:

要在 bpmn.js 中实现校验当前画布上只能有一个开始节点,可以在 saveFlow 方法中进行检查。以下是一个示例代码,展示了如何实现这一功能:

  1. 获取所有元素:使用 modeling 服务获取当前画布上的所有元素。
  2. 过滤开始节点:从所有元素中过滤出开始节点。
  3. 校验数量:检查开始节点的数量是否为1。
<template><div id="app"><!-- 你的 BPMN 画布和其他组件 --></div>
</template><script>
import BpmnModeler from 'bpmn-js/lib/Modeler';
import propertiesPanelModule from 'bpmn-js-properties-panel';
import propertiesProviderModule from 'bpmn-js-properties-panel/lib/provider/camunda';export default {data() {return {bpmnModeler: null,};},mounted() {this.initBpmnModeler();},methods: {initBpmnModeler() {this.bpmnModeler = new BpmnModeler({container: '#app',additionalModules: [propertiesPanelModule,propertiesProviderModule]});// 加载你的 BPMN 文件this.bpmnModeler.importXML(yourBpmnXml, (err) => {if (err) {console.error('Failed to load BPMN file', err);} else {console.log('BPMN file loaded successfully');}});},saveFlow() {const { modeling, elementRegistry } = this.bpmnModeler.get('modeling');// 获取所有元素const allElements = elementRegistry.getAll();// 过滤出开始节点const startEvents = allElements.filter(element => element.type === 'bpmn:StartEvent');// 校验开始节点的数量if (startEvents.length !== 1) {alert('画布上必须且只能有一个开始节点');return;}// 如果校验通过,继续保存流程this.bpmnModeler.saveXML({ format: true }, (err, { xml }) => {if (err) {console.error('Failed to save BPMN file', err);} else {console.log('BPMN file saved successfully', xml);// 你可以在这里将 XML 发送到服务器}});}}
};
</script><style>
/* 你的样式 */
</style>

解释

  1. 初始化 BpmnModeler
    • 在 mounted 生命周期钩子中初始化 BpmnModeler,并加载 BPMN 文件。
  2. saveFlow 方法
    • 获取 modeling 和 elementRegistry 服务。
    • 使用 elementRegistry.getAll() 获取画布上的所有元素。
    • 使用 filter 方法过滤出类型为 bpmn:StartEvent 的元素。
    • 检查过滤后的数组长度是否为1,如果不是,则弹出提示并返回。
    • 如果校验通过,调用 saveXML 方法保存 BPMN 文件。

这样,你就可以确保在保存流程之前,画布上只有一个开始节点。

我:报错:TypeError: Cannot read properties of undefined (reading 'getAll')

通义灵码:

报错 TypeError: Cannot read properties of undefined (reading 'getAll') 表明 elementRegistry 未正确获取到。这通常是因为 get 方法没有正确地从 bpmnModeler 中获取到 elementRegistry 服务。

我们可以通过以下步骤来解决这个问题:

  1. 确保 bpmnModeler 已经初始化完成
  2. 正确获取 elementRegistry 服务

以下是修正后的代码:

<template><div id="app"><!-- 你的 BPMN 画布和其他组件 --></div>
</template><script>
import BpmnModeler from 'bpmn-js/lib/Modeler';
import propertiesPanelModule from 'bpmn-js-properties-panel';
import propertiesProviderModule from 'bpmn-js-properties-panel/lib/provider/camunda';export default {data() {return {bpmnModeler: null,};},mounted() {this.initBpmnModeler();},methods: {initBpmnModeler() {this.bpmnModeler = new BpmnModeler({container: '#app',additionalModules: [propertiesPanelModule,propertiesProviderModule]});// 加载你的 BPMN 文件this.bpmnModeler.importXML(yourBpmnXml, (err) => {if (err) {console.error('Failed to load BPMN file', err);} else {console.log('BPMN file loaded successfully');}});},saveFlow() {// 确保 bpmnModeler 已经初始化if (!this.bpmnModeler) {console.error('BPMN Modeler is not initialized');return;}const elementRegistry = this.bpmnModeler.get('elementRegistry');// 获取所有元素const allElements = elementRegistry.getAll();// 过滤出开始节点const startEvents = allElements.filter(element => element.type === 'bpmn:StartEvent');// 校验开始节点的数量if (startEvents.length !== 1) {alert('画布上必须且只能有一个开始节点');return;}// 如果校验通过,继续保存流程this.bpmnModeler.saveXML({ format: true }, (err, { xml }) => {if (err) {console.error('Failed to save BPMN file', err);} else {console.log('BPMN file saved successfully', xml);// 你可以在这里将 XML 发送到服务器}});}}
};
</script><style>
/* 你的样式 */
</style>

解释

  1. 确保 bpmnModeler 已经初始化
    • 在 saveFlow 方法中,首先检查 bpmnModeler 是否已经初始化。如果没有初始化,输出错误信息并返回。
  2. 正确获取 elementRegistry 服务
    • 使用 this.bpmnModeler.get('elementRegistry') 获取 elementRegistry 服务。
  3. 获取所有元素
    • 使用 elementRegistry.getAll() 获取画布上的所有元素。
  4. 过滤开始节点
    • 使用 filter 方法过滤出类型为 bpmn:StartEvent 的元素。
  5. 校验开始节点的数量
    • 检查过滤后的数组长度是否为1,如果不是,则弹出提示并返回。
  6. 保存流程
    • 如果校验通过,调用 saveXML 方法保存 BPMN 文件。

这样可以确保 elementRegistry 服务正确获取,并且在 bpmnModeler 未初始化时不会尝试访问其属性。

修正后的代码是可用的。至此,问题解决。

相关文章:

用通义灵码帮助实现校验bpmn.js当前画布上只能有一个开始节点的功能

最终代码&#xff1a; const elementRegistry this.bpmnModeler.get(elementRegistry);// 获取所有元素const allElements elementRegistry.getAll();// 过滤出开始节点const startEvents allElements.filter(element > element.type bpmn:StartEvent);// 校验开始节点的…...

OKHTTP断点续传

OKHTTP断点续传 文章目录 OKHTTP断点续传HTTP断点续传知识点RangeContent RangeEtag&If-Range&#xff08;文件唯一标志&#xff09; OKHTTP断点下载OKHTTP 简单短断点下载代码示例 Android 断点续传一直是面试的高频问点&#xff0c;这里从HTTP断点续传知识和Android续传思…...

软件测试学习笔记丨Flask操作数据库-ORM

本文转自测试人社区&#xff0c;原文链接&#xff1a;https://ceshiren.com/t/topic/23426 什么是持久化 是把数据保存到可永久保存的存储设备中&#xff08;比如磁盘&#xff09;。持久化的主要应用是将内存中的数据存储在关系型数据库中&#xff0c;当然也可以存储在磁盘文件…...

ABAP 开发的那些小技巧

在对话框程序中的选择屏幕添加图标 要在选择屏幕中添加图标&#xff0c;其中包括参数&#xff1a; 在参数的选择文本中或选择选项(select-option)中写入 01 或选择选项&#xff1a; 您可以使用 01、02、03&#xff0c;依此类推&#xff0c;以获取不同的不同图标。 在运行时…...

电科金仓(人大金仓)更新授权文件(致命错误: XX000: License file expired.)

问题:电科金仓(人大金仓)数据库链接异常,重启失败,查看日志如下: 致命错误: XX000: License file expired. 位置: PostmasterMain, postmaster.c:725 解决方法: 一、下载授权文件 根据安装版本在官网下载授权文件(电科金仓-成为世界卓越的数据库产品与服务提供商)…...

玩转「HF/魔搭/魔乐」平台

模型下载 Hugging Face 下载到 GitHub CodeSpace CodeSpace创建环境&#xff1a; # 安装transformers pip install transformers4.38 pip install sentencepiece0.1.99 pip install einops0.8.0 pip install protobuf5.27.2 pip install accelerate0.33.0下载internlm2_5-7b…...

鸿蒙系统的优势 开发 环境搭建 开发小示例

HarmonyOS是面向多智能终端、全场景的分布式操作系统,为消费者提供跨终端的无缝体验.华为开发者联盟从HarmonyOS应用设计、开发、测试、推广变现等环节全方位助力开发者。 开发者可以通过以下步骤学习鸿蒙系统的开发&#xff1a; 基础理论学习&#xff1a; 了解鸿蒙系统概述&a…...

python批量合并excel文件

当工作中发现有多个excel表需要进行相同的操作或者需要汇总在一起&#xff0c;一个一个处理太费时间&#xff0c;以下的python代码能够帮你解决这个问题~ import pandas as pd import os# 设置Excel文件所在的文件夹路径和合并文件的输出路径 folder_path D:\\Desktop\\dat…...

AWS S3 JavaScript SDK(v3)常用操作

安装 aws s3 sdk npm install aws-sdk/client-s3配置 创建 ~/.aws/credentials 文件&#xff0c;添加以下配置项&#xff1a; [default] aws_access_key_id<...> aws_secret_access_key<...> region<...>S3 SDK常用桶操作 获取桶列表 import {S3Client,…...

数据结构——图的基本操作

文章目录 1.图2.图的结构体定义3.图的初始化4.添加顶点、删除顶点4.1添加顶点4.2删除顶点 5.添加边、删除边5.1添加边5.2删除边 6.打印图7.main函数 在生命旅途中&#xff0c;我们就像是一个个节点&#xff0c;被无数看不见的边相连。每一次的相识与相离&#xff0c;都在这张巨…...

掌握全球速递:在表格中高效利用国际快递公式查询快递

在当今全球化的商业环境中&#xff0c;国际快递服务已成为连接世界各地企业与个人的重要桥梁。无论是跨国企业间的货物运输&#xff0c;还是个人用户的海外购物需求&#xff0c;国际快递都扮演着不可或缺的角色。然而如何快速准确地获取大量国际快递的物流轨迹成为了一个挑战。…...

【MySQL系列】字符集设置

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

Vue2进阶之Vue3高级用法

Vue3高级用法 响应式Vue2&#xff1a;Object.definePropertyObject.definePropertythis.$set设置响应式 Vue3&#xff1a;Proxy composition APIVue2 option API和Vue3 compositionAPIreactive和shallowReactivereadonly效果toRefs效果 生命周期main.jsindex.htmlLifeCycle.vue…...

基于微信的追星小程序+ssm(lw+演示+源码+运行)

摘 要 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据信息管理&#xff0c;对于手机的各种软件也是备受用户的喜爱&#xff0c;追星小程序被用户普遍使用&#xff0c;为方便用户能够可以…...

【51单片机】串口通信原理 + 使用

学习使用的开发板&#xff1a;STC89C52RC/LE52RC 编程软件&#xff1a;Keil5 烧录软件&#xff1a;stc-isp 开发板实图&#xff1a; 文章目录 串口硬件电路UART串口相关寄存器 编码单片机通过串口发送数据电脑通过串口发送数据控制LED灯 串口 串口是一种应用十分广泛的通讯接…...

优选算法第五讲:位运算模块

优选算法第五讲&#xff1a;位运算模块 1.常见的位运算总结2.判断字符是否唯一3.丢失的数字4.两整数之和5.只出现一次的数字II6.消失的两个数字 1.常见的位运算总结 2.判断字符是否唯一 链接: link class Solution { public:bool isUnique(string astr) {if(astr.size() >…...

【07】Maven项目多环境打包配置

&#xff08;1&#xff09;Web项目使用Maven进行多模块划分开发之后&#xff0c;面临一个问题&#xff0c;即如何加载不同环境的配置文件打包发布到不同的环境中&#xff1f; &#xff08;2&#xff09;不同的环境有开发环境、测试环境、线上生产环境等。 &#xff08;3&#x…...

嵌入式Linux入门具备:C语言基础与基本驱动学习(2):Linux GIibc IO基础

标准IO 标准 I/O 虽然是对文件 I/O 进行了封装&#xff0c;但事实上并不仅仅只是如此&#xff0c;标准 I/O 会处理很多细节&#xff0c;譬如分配 stdio 缓冲区、以优化的块长度执行 I/O 等&#xff0c;这些处理使用户不必担心如何选择使用正确的块长度。I/O 库函数是构建于文件…...

【微服务】Docker 容器化

一、初识Docker 1. 为什么需要 Docker 大型项目组件较多&#xff0c;运行环境也较为复杂&#xff0c;部署时会遇到一些问题&#xff1a; 依赖关系复杂&#xff0c;容易出现兼容性的问题开发、测试、生产环境有差异 Docker 如何解决依赖的兼容问题 将应用的Libs&#xff08;…...

[前端] 为网站侧边栏添加搜索引擎模块

前言 最近想给我的个人网站侧边栏添加一个搜索引擎模块&#xff0c;可以引导用户帮助本站SEO优化&#xff08;让用户可以通过点击搜索按钮完成一次对本人网站的搜索&#xff0c;从而实现对网站的搜索引擎优化&#xff09;。 最开始&#xff0c;我只是想实现一个简单的百度搜索…...

【人工智能】神经网络的优化器optimizer(二):Adagrad自适应学习率优化器

一.自适应梯度算法Adagrad概述 Adagrad&#xff08;Adaptive Gradient Algorithm&#xff09;是一种自适应学习率的优化算法&#xff0c;由Duchi等人在2011年提出。其核心思想是针对不同参数自动调整学习率&#xff0c;适合处理稀疏数据和不同参数梯度差异较大的场景。Adagrad通…...

PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建

制造业采购供应链管理是企业运营的核心环节&#xff0c;供应链协同管理在供应链上下游企业之间建立紧密的合作关系&#xff0c;通过信息共享、资源整合、业务协同等方式&#xff0c;实现供应链的全面管理和优化&#xff0c;提高供应链的效率和透明度&#xff0c;降低供应链的成…...

【项目实战】通过多模态+LangGraph实现PPT生成助手

PPT自动生成系统 基于LangGraph的PPT自动生成系统&#xff0c;可以将Markdown文档自动转换为PPT演示文稿。 功能特点 Markdown解析&#xff1a;自动解析Markdown文档结构PPT模板分析&#xff1a;分析PPT模板的布局和风格智能布局决策&#xff1a;匹配内容与合适的PPT布局自动…...

Nuxt.js 中的路由配置详解

Nuxt.js 通过其内置的路由系统简化了应用的路由配置&#xff0c;使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...

Go 语言并发编程基础:无缓冲与有缓冲通道

在上一章节中&#xff0c;我们了解了 Channel 的基本用法。本章将重点分析 Go 中通道的两种类型 —— 无缓冲通道与有缓冲通道&#xff0c;它们在并发编程中各具特点和应用场景。 一、通道的基本分类 类型定义形式特点无缓冲通道make(chan T)发送和接收都必须准备好&#xff0…...

关于easyexcel动态下拉选问题处理

前些日子突然碰到一个问题&#xff0c;说是客户的导入文件模版想支持部分导入内容的下拉选&#xff0c;于是我就找了easyexcel官网寻找解决方案&#xff0c;并没有找到合适的方案&#xff0c;没办法只能自己动手并分享出来&#xff0c;针对Java生成Excel下拉菜单时因选项过多导…...

MySQL 主从同步异常处理

阅读原文&#xff1a;https://www.xiaozaoshu.top/articles/mysql-m-s-update-pk MySQL 做双主&#xff0c;遇到的这个错误&#xff1a; Could not execute Update_rows event on table ... Error_code: 1032是 MySQL 主从复制时的经典错误之一&#xff0c;通常表示&#xff…...

【WebSocket】SpringBoot项目中使用WebSocket

1. 导入坐标 如果springboot父工程没有加入websocket的起步依赖&#xff0c;添加它的坐标的时候需要带上版本号。 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-websocket</artifactId> </dep…...

Java详解LeetCode 热题 100(26):LeetCode 142. 环形链表 II(Linked List Cycle II)详解

文章目录 1. 题目描述1.1 链表节点定义 2. 理解题目2.1 问题可视化2.2 核心挑战 3. 解法一&#xff1a;HashSet 标记访问法3.1 算法思路3.2 Java代码实现3.3 详细执行过程演示3.4 执行结果示例3.5 复杂度分析3.6 优缺点分析 4. 解法二&#xff1a;Floyd 快慢指针法&#xff08;…...

Python学习(8) ----- Python的类与对象

Python 中的类&#xff08;Class&#xff09;与对象&#xff08;Object&#xff09;是面向对象编程&#xff08;OOP&#xff09;的核心。我们可以通过“类是模板&#xff0c;对象是实例”来理解它们的关系。 &#x1f9f1; 一句话理解&#xff1a; 类就像“图纸”&#xff0c;对…...