第六章 activiti流程 “动态表单实验室”

一、任务表单是什么?------流程的"体检表"

1. 表单的核心作用
  • 数据采集:在任务处理时收集业务数据(如请假天数、报销金额)。
  • 动态渲染:根据流程变量或用户角色展示不同字段。
  • 数据绑定:将表单输入自动映射到流程变量。
2. 表单类型对比
类型 存储方式 适用场景
动态表单 嵌入BPMN文件 简单字段,快速开发
外部表单 独立HTML/JSP文件 复杂UI,需要自定义样式

二、动态表单设计------BPMN中的"隐形问卷"

1. 在BPMN中定义表单属性

在用户任务节点中添加activiti:formProperty

xml 复制代码
<userTask id="leaveApply" name="请假申请">  
  <extensionElements>  
    <activiti:formProperty id="days" name="请假天数" type="long" required="true"/>  
    <activiti:formProperty id="reason" name="请假理由" type="string"/>  
  </extensionElements>  
</userTask>  

参数解析

  • type:支持string, long, date, boolean等类型。
  • required:是否必填。
2. 代码中获取表单数据
java 复制代码
Task task = taskService.createTaskQuery().taskId(taskId).singleResult();  
List<FormProperty> formProperties = formService.getTaskFormData(task.getId()).getFormProperties();  

// 渲染到前端  
formProperties.forEach(prop -> {  
    System.out.println("字段名:" + prop.getName() + ", 类型:" + prop.getType());  
});  

三、外部表单开发------HTML的"自由舞台"

1. 创建独立HTML表单
html 复制代码
<form action="/complete-task" method="post">  
  <input type="hidden" name="taskId" value="${taskId}">  
  请假天数:<input type="number" name="days" required>  
  请假理由:<textarea name="reason"></textarea>  
  <button type="submit">提交</button>  
</form>  
2. 提交表单数据到引擎
java 复制代码
@PostMapping("/complete-task")  
public String completeTask(@RequestParam String taskId, @RequestParam Map<String, String> formData) {  
    formService.submitTaskFormData(taskId, formData);  
    return "redirect:/tasks";  
}  

关键点 :表单参数的name必须与流程变量名一致!


四、表单数据与流程变量的"量子纠缠"

1. 自动绑定规则
  • 表单字段名与流程变量名同名时自动绑定。
  • 例如:表单中的days字段 → 自动存入流程变量days
2. 手动绑定数据
java 复制代码
Map<String, Object> variables = new HashMap<>();  
variables.put("days", formData.get("days"));  
variables.put("reason", formData.get("reason"));  
taskService.complete(taskId, variables);  

五、表单渲染与验证------让输入"守规矩"

1. 动态渲染字段

根据用户角色隐藏/显示字段:

html 复制代码
<% if (user.isManager()) { %>  
  审批意见:<input type="text" name="comment">  
<% } %>  
2. 后端验证逻辑
java 复制代码
if (formData.get("days") == null || Integer.parseInt(formData.get("days")) <= 0) {  
    throw new ActivitiException("请假天数必须大于0!");  
}  

六、避坑指南------表单的"隐藏陷阱"

1. 表单未绑定变量

症状 :提交后流程变量为空。
检查项

  • 表单字段名是否与流程变量名一致。
  • 是否调用formService.submitTaskFormDatataskService.complete
2. 外部表单路径错误

症状 :访问表单404报错。
解法 :确保HTML文件放在src/main/resources/static目录下。


七、课后挑战------巩固你的"表单魔法"

  1. 选择题 :动态表单的字段类型date对应的Java类型是?

    A. java.util.Date

    B. String

    C. Long

  2. 实战题:设计一个报销表单,包含"金额(double)、发票附件(file)"字段,并实现后端提交验证。


相关推荐
武子康3 分钟前
Java-39 深入浅出 Spring - AOP切面增强 核心概念 通知类型 XML+注解方式 附代码
xml·java·大数据·开发语言·后端·spring
米粉030513 分钟前
SpringBoot核心注解详解及3.0与2.0版本深度对比
java·spring boot·后端
一只帆記1 小时前
SpringBoot EhCache 缓存
spring boot·后端·缓存
yuren_xia4 小时前
Spring Boot中保存前端上传的图片
前端·spring boot·后端
JohnYan7 小时前
Bun技术评估 - 04 HTTP Client
javascript·后端·bun
shangjg37 小时前
Kafka 的 ISR 机制深度解析:保障数据可靠性的核心防线
java·后端·kafka
青莳吖8 小时前
使用 SseEmitter 实现 Spring Boot 后端的流式传输和前端的数据接收
前端·spring boot·后端
我的golang之路果然有问题9 小时前
ElasticSearch+Gin+Gorm简单示例
大数据·开发语言·后端·elasticsearch·搜索引擎·golang·gin
mldong11 小时前
我的全栈工程师之路:全栈学习路线分享
前端·后端
噼里啪啦啦.11 小时前
SpringBoot统一功能处理
java·spring boot·后端