第二章 若依JFlow流程模型设计
若依-JFlow框架如何拉取、配置并运行请查看这篇文章:《第一章 若依-JFlow的配置与启动》
上一节我们讲解了如何拉取若依-JFlow框架代码并配置运行,这一部分我们就以公司员工请假的流程为例,设计一个流程,并为初始节点设计一个表单。
一、新建业务场景和流程模型
1. 启动项目以后,登录管理员账号(用户名:admin,密码:admin123),进入系统首页:
2. 创建流程:点击左侧第二个JFlow流程设计,再点击流程模板:
3. 系统中,流程树已经定义了一些业务场景(即不同的文件夹)如下图所示:
和文件夹的创建方式一样,我们只需要鼠标右键,点击新建子级目录即可创建一个业务场景,如果需要删除,就点击删除目录即可:
这里我创建一个名为业务场景231204
的业务场景:
4. 创建流程模型:点击右上角新建流程
5. 流程名称自定义,设计模式选择专业模式即可,完成后点击右上角创建流程:
如果此时创建完成后,浏览器对弹出窗口拦截时,直接点击拦截窗口,选择始终允许弹出窗口并从http://localhost:8089重定向,然后点击完成即可:
6. 此时就会弹出一个流程设计的窗口:
设计流程一共有五个步骤:
- 绘制流程图
- 设置接收人规则
- 设计表单
- 检查流程
- 测试并运行该流程
二、绘制流程图
1. 一个流程是由一个个流程节点组成的,如下图所示,Start Node和Node 2都是这个流程图的节点,绿色标志的是开始节点:
2. 鼠标右键点击空白处,可以新建节点:
3. 双击某个节点可以修改该节点的名称:
4. 要想将两个节点连接起来,长按该节点的图标,然后将连接线拉向另一个节点:
当然,如果你需要对连接线上添加文字说明,双击连接线即可:
如需删除连接线,也需要双击连接线,点击删除即可:
以下是一个简单的请假的流程模型:
三、设置接收人规则
接收人规则是指当前节点完成任务以后,这个任务转到下一节点时,由谁来处理。
JFlow默认的处理规则是:上一个节点选择那一个人(或者部门),就由这个人(部门)来处理。当然,我们也可以自行设计接收人规则。
鼠标右键点击节点,选择节点属性
接下来,我们就按照正常的请假流程设置每一个节点的接收人规则:
1. 员工填写请假单:我们假设公司所有的员工都可以填写请假单,因此规则设定为:所有的人员都可以发起:
2. 部门领导审批:假设每一个员工都处于一个部门,那么员工要将请假单交给对应部门领导审批:
假设部门领导角色是开发组长,这里选择程序员,点击保存,然后关闭此窗口:
接收人规则页面也点击保存即可:
3. 人事签字备案:设置规则和部门领导审批基本相同,分组模式中选择人力资源部经理审批即可:
4. 总经理审批亦同理,分组模式中选择总经理审批即可:
5. 查看请假单信息:由于是公司员工发起的请假申请,因此查看请假单信息应该由开始节点员工对应
至此,整个请假流程的所有接收人规则设置完成。
四、设计单个节点表单
4.1 表单方案的说明
鼠标右键点击节点,点击表单方案。
系统默认给我们提供的是傻瓜表单。
傻瓜表单指的是在一个表单中,对应一个标签和一个控件,例如:如果标签为姓名,那么控件对应的就是文本框;如果填写的是性别,那么需要填写的控件是单选框。
对于小白而言,选择傻瓜表单即可应对多种场景。当然,JFlow还为我们提供了更多的表单方案:
4.2 请假单页面分析与设计
接下来,我们就是用表单方案,设计各级角色的请假申请单。
1. 员工填写请假单:鼠标右键点击节点,选择设计表单。进入表单设计页面:
2. 对于申请人而言,需要填写申请人姓名、所在部门名称、申请日期、请假类别(例如:事假、病假、婚假、丧假等)、请假事由、请假开始时间、请假结束时间、请假时长计算。
- 对于申请人姓名、所在部门名称、申请日期我们只需要保证能获取到当前登录用户的信息和填写申请所在日期即可,直接让系统自动生成,不需要人为填写。
- 请假类别对应的控件需要设置成单选框(假设请假只有一种情况)。
- 请假开始时间、结束时间需要使用时间输入框。并且开始时间必须保证是今天及之后,结束时间必须是开始时间及之后。
- 请假时长需要根据请假时间开始时间和请假结束时间计算即可。
4.3 绘制请假单基本框架
按照前面对请假单页面的分析,绘制请假单。
1. 申请人姓名:在左侧组件的基本字段中选中文字框拖入到中间区域,此时弹出一个提示框,这里我们组件名称为申请人姓名,组件id按照系统默认生成的即可,完成后点击继续添加:
2. 接下来组件名称填写为申请人所在部门,然后点击创建并继续添加:
3. 申请日期的输入框类型是日期类型,然后填写组件名称,然后点击创建即可:
4. 此时表单如下图所示:
5. 请假事由是一个文本框,将左面文字组件拖入到表单即可:
6. 添加请假开始时间和请假结束时间,选择日期组件,输入格式设定为日期即可:
7. 请假时长控件的输入框类型选择数值即可:
8. 至此,我们的请假单基本框架就绘制完成了,如下图所示:
4.4 对请假单进一步完善
1. 按照上面我们指定的要求:申请人姓名、所在部门、申请日期由系统自动生成,并且设置为只读。那么我们需要对这三个控件分别操作。
- 首先,点击申请人姓名,点击小齿轮,进入组件设置:
- 我们能看到当前组件的基本信息,将系统默认值设置为登陆人员名称,然后点击保存,然后关闭这个窗口即可。
- 此时申请人姓名组件中文本框出现一个
@WebUser.Name
的标识,这是我们上一步设置的结果,不用修改。
- 申请人所在部门的设置和申请人姓名设置基本相同,只不过将系统默认值改为登陆人员部门名称:
- 申请日期的系统默认值设置为
@RDT
表示当前日期:
- 设置完成后的表单如下图所示,我们需要将这三个组件设置为只读禁止修改:
- 以申请人姓名组件为例,我们选中这个组件,然后在右侧开启是否只读:
- 申请人所在部门、申请日期的设置只读方式和前面的相同,设置完成后的效果图如下:
2. 接下来,我们再添加两个组件:请假类别、请假事由。
- 请假类别我们使用枚举单选控件,将其拉入表单中,此时会弹出一个添加枚举值字段的窗口,点击新建:
- 标签填写请假类别,对应的类别名称我们填写到下面的枚举框中,完成后点击保存:
- 选择请假类别的枚举值:
- 弹出框的内容,点击确定:
- 点击保存:
- 选择请假事由组件,在右侧组件设置中的文本类型设置为大块文本,开启超长文本,控件栅格选择整行:
3. 接下来,我们为开始时间、结束时间、请假时长这三个组件设置规则:
- 选中开始时间,点击齿轮,修改组件基本信息:选择日期输入限制,输入日期大于或等于当前日期,设置规则如下图所示:
- 选中结束时间,点击齿轮,修改组件基本信息:选择日期输入限制,输入日期大于等于请假开始时间,设置规则如下图所示:
- 选中请假时长,点击齿轮,修改组件基本信息:
- 为了更好向用户展示请假时长,我们需要对请假时长设置时间单位,由于我们在前面选择的是日期格式,因此请假时长单位是以天为单位:选中组件,在右侧组件设置的后置提示设置为“天”
- 请假是由用户填写上述的上述的开始日期和结束日期,经过系统计算而得出的,因此这一部分不需要我们填写,我们把这个控件设置为只读即可:选中请假时长控件,在右侧开启是否只读:
4. 点击最外面的组件,在右侧我们修改一下组件名字为:请假申请单
5. 至此,“员工填写请假申请”节点的表单绘制完成,效果图如下图所示:
当然,我们只绘制了一个节点表单,那么其他节点的表单也在上述表单的基础上进行绘制。如何在这个表单的基础上绘制其他节点的表单,以及后续所有表单绘制完成后的操作如何,我们放到下一篇文章讲解。
第二章 若依JFlow流程模型设计的更多相关文章
- PHP:第二章——PHP中的流程控制语句
if语句的集中形式 <?php /*if(条件) 语句; if(条件){语句块} if(条件){语句或语句块}else{语句或语句块} if(条件){语句或语句块}elseif(条件){语句或语 ...
- 《Entity Framework 6 Recipes》翻译系列 (3) -----第二章 实体数据建模基础之创建一个简单的模型
第二章 实体数据建模基础 很有可能,你才开始探索实体框架,你可能会问“我们怎么开始?”,如果你真是这样的话,那么本章就是一个很好的开始.如果不是,你已经建模,并在实体分裂和继承方面感觉良好,那么你可以 ...
- 精通Web Analytics 2.0 (4) 第二章:选择你的网络分析灵魂伴侣的最佳策略
精通Web Analytics 2.0 : 用户中心科学与在线统计艺术 第二章:选择你的网络分析灵魂伴侣的最佳策略 在Web Analytics 2.0的新世界秩序中,您必须跳出"单一真理来 ...
- MVC5+EF6 简易版CMS(非接口) 第二章:建数据模型
目录 简易版CMS后台管理系统开发流程 MVC5+EF6 简易版CMS(非接口) 第一章:新建项目 MVC5+EF6 简易版CMS(非接口) 第二章:建数据模型 MVC5+EF6 简易版CMS(非接口 ...
- CISA 信息系统审计知识点 [第二章. IT治理和管理 ]
第二章. IT治理和管理 1. IT治理.管理.安全和控制框架及标准.指南和实践 IT治理是董事会和执行管理层的职责. IT治理的关键因素:保持与业务的战略一致,引导业务价值的实现. IT治理关注 ...
- Laxcus大数据管理系统2.0(5)- 第二章 数据组织
第二章 数据组织 在数据的组织结构设计上,Laxcus严格遵循数据和数据描述分离的原则,这个理念与关系数据库完全一致.在此基础上,为了保证大规模数据存取和计算的需要,我们设计了大量新的数据处理技术.同 ...
- java面向对象编程——第二章 java基础语法
第二章 java基础语法 1. java关键字 abstract boolean break byte case catch char class const continue default do ...
- 学习opencv中文版教程——第二章
学习opencv中文版教程——第二章 所有案例,跑起来~~~然而并没有都跑起来...我只把我能跑的都尽量跑了,毕竟看书还是很生硬,能运行能出结果,才比较好. 越着急,心越慌,越是着急,越要慢,越是陌生 ...
- (转)iOS Wow体验 - 第二章 - iOS用户体验解析(2)
本文是<iOS Wow Factor:Apps and UX Design Techniques for iPhone and iPad>第二章译文精选的第二部分,其余章节将陆续放出.上一 ...
- 微信小程序教学第二章:小程序中级实战教程之预备篇 - 项目结构设计 |基于最新版1.0开发者工具
iKcamp官网:http://www.ikcamp.com 访问官网更快阅读全部免费分享课程:<iKcamp出品|全网最新|微信小程序|基于最新版1.0开发者工具之初中级培训教程分享>. ...
随机推荐
- PyAV 使用浅谈
背景: PyAV是一个用于音频和视频处理的Python库,它提供了一个简单而强大的接口,用于解码.编码.处理和分析各种音频和视频格式.PyAV基于FFmpeg多媒体框架,它本质上是FFmpeg 的Py ...
- 简单描述下HTTP协议和TCP协议之间的关系以及TCP三次握手, 四次挥手
TCP 三次握手, 四次挥手 TCP(传输控制协议)是一种用于在计算机网络中建立可靠连接的协议.TCP连接的建立和终止分别使用了"三次握手"和"四次挥手"的过程 ...
- 使用API调用获取商品数据的完整方案
在电子商务应用程序中,商品详情接口是不可或缺的一部分.它用于从电商平台或自己的数据库中获取商品数据,并将其提供给应用程序的其他部分使用.本文将详细介绍如何设计一个完整的商品详情接口方案,其中包括使 ...
- 如何通过拼多多订单API接口获取订单详情
要获取拼多多订单详情,可以使用以下接口: 1. API名称:pdd.order.detail.get 接口说明:此接口用于查询某个订单的详情信息. API文档地址:前往注册 调用该接口需要提供以下参数 ...
- mall :hutool项目源码解析
目录 一.mall开源项目 1.1 来源 1.2 项目转移 1.3 项目克隆 二.Hutool工具类库 2.1 Hutool 简介 三.源码解析 3.1 集成与配置 3.1.1 导入依赖 3.1.2 ...
- 《Python魔法大冒险》007 被困的精灵:数据类型的解救
小鱼和魔法师深入魔法森林,树木之间流淌着神秘的光芒,每一片叶子都似乎在低语着古老的咒语.不久,他们来到了一个小湖旁,湖中央有一个小岛,岛上困着一个透明的泡泡,里面有一个悲伤的精灵. 小鱼看着那个精灵, ...
- Solution -「洛谷 P4451」「国家集训队」整数的 lqp 拆分
Description Link. 求 \[\sum\prod_{i=1}^{m}F_{a_{i}},(m>0,a_{1},\cdots a_{m}>0,\sum a_{i}=n) \] ...
- c语言代码练习7
//输出0-100的三倍数字#define _CRT_SECURE_NO_WARNINGS 1 #include <stdio.h> int main() { int i = 0; int ...
- JS逆向实战23 某市wss URL加密+请求头+ws收发
声明 本文章中所有内容仅供学习交流,抓包内容.敏感网址.数据接口均已做脱敏处理,严禁用于商业用途和非法用途,否则由此产生的一切后果均与作者无关,若有侵权,请联系我立即删除! 本文首发链接为: http ...
- android 反编译 apk 分享 smali2java 1.0.0.558
smali2java 1.0.0.558 smali2java是一个将smali代码反编译成java代码的工具. 什么是smali?smali是将Android字节码用可阅读的字符串形式表现出来的一种 ...