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

一、任务表单是什么?——流程的“体检表”

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

二、动态表单设计——BPMN中的“隐形问卷”

1. 在BPMN中定义表单属性

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

<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. 代码中获取表单数据
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表单
<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. 提交表单数据到引擎
@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. 手动绑定数据
Map<String, Object> variables = new HashMap<>();  
variables.put("days", formData.get("days"));  
variables.put("reason", formData.get("reason"));  
taskService.complete(taskId, variables);  

五、表单渲染与验证——让输入“守规矩”

1. 动态渲染字段

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

<% if (user.isManager()) { %>  
  审批意见:<input type="text" name="comment">  
<% } %>  
2. 后端验证逻辑
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)”字段,并实现后端提交验证。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值