SharePoint 2013 Designer工作流——Parallel Block的应用
参考目录
在自定义Workflow时,往往会遇到这样场景,某个审批需要被多人查阅,每个查阅的审批人之间互相独立,即彼此互不影响,简单来说就是:"一人通过,审批通过;一人拒绝,审批拒绝"。这就像是中学物理中的并联电路,相对于串联电路,并联电路更加灵活。
在SharePoint Workflow中,也提供了类似并联电路的活动,即Parallel Block(并行程序块),在SharePoint Designer 2013中,位于工具栏中,如下所示:
要使用此活动也是很简单,接下来我以一个简单的入网申请来演示,假设有如下场景
公元前211年,秦朝的科技已如日中天,信息化建设也属七国中翘楚,为了更加集权监督,始皇帝决定三公九卿人人配置移动设备,时刻汇报日常工作。现御史大夫张学友购入设备一台,急需入网申报奏折。
设备入网申请
- 创建对应的List,Task,添加如下图所示的Column,具体细节详情此文中的设置。
打开SharePoint Designer,选择需要关联的List,创建自定义的工作流。
- 首先,新建并初始化变量,如下所示:
- 接着,插入Parallel Block,并在其中添加Step,在每个Step中分配需要的任务,如下图所示:
- 然后,右键单击Parallel Block(并行运算),选择高级属性,这时会弹出如下提示框:
可以看到CompletionCondition是一个Boolean类型的属性。它表示若属性值为True,即只要其中一个任务分支执行完毕,那么在并行块中的其他任务分支将被取消,即不执行。反之,若CompleteCondition为False时,那么在此并行块中所有已经执行完毕的任务分支都将等待,直到最后一个任务分支都执行完毕。
- 最后,对审批的结果进行判断,需要IF…ELSE 条件来进行逻辑处理,如下所示:
入网申请测试
当张学友发起入网申请时,工作流启动,并同时分配任务给指定的参与人(分配的任务存储在Task中)。由于分配的任务之间是并行关系,并且CompleteCondition位True,所以互相的操作不受影响,即"一人通过,审批通过;一人拒绝,审批拒绝"。
- 所以,当张学友提交入网申请时,嬴政、赵高同时收到审批任务,如下所示:
- 指定的参与人收到任务后,即可进行审批。当赵高审批通过,分配给嬴政的任务已没有意义,会自动删除,如下图所示:
小结
上述描述的工作流仅仅是Demo级别,对于复杂的业务,特别是权限的控制,SharePoint 2013 Workflow给我的感觉依然是捉襟见肘。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· spring官宣接入deepseek,真的太香了~