上一章我们给系统加上了权限,不同角色看到不同的内容。但所有操作还是靠人手动完成——新工单来了要自己去看,状态改了没人知道。
这一章,我们让系统自动干活。
工作流就是一套自动化的"如果……那么……"规则。
打个比方:你手机上设了个闹钟,每天早上 8 点响。闹钟就是最简单的工作流——条件满足(到了 8 点),就自动执行(响铃)。
NocoBase 的工作流也是同样的思路:
工作流的执行动作可以串联多个节点,常用的节点类型有:
本教程只用到其中最常见的几个,学会组合后就能应对大多数场景。
NocoBase 提供了多种触发器类型,在创建工作流时选择:
| 触发器 | 说明 | 典型场景 |
|---|---|---|
| 数据表事件 | 数据新增、更新或删除时触发 | 新工单通知、状态变更记录 |
| 定时任务 | 按 Cron 表达式或固定时间触发 | 每天生成日报、定期清理过期数据 |
| 操作后事件 | 用户在界面执行操作后触发 | 表单提交后发送通知 |
| 审批 | 发起审批流程,支持多级审批 | 请假审批、采购审批 |
| 自定义操作 | 绑定到自定义按钮,点击触发 | 一键归档、批量操作 |
| 操作前事件 | 拦截用户操作,同步执行后再放行 | 提交前校验、自动补全字段 |
| AI 员工 | 将工作流作为工具提供给 AI 员工调用 | AI 自动执行业务操作 |
本教程会用到 数据表事件 和 操作后事件 两种触发器,其他类型的用法类似,学会后就能举一反三。
NocoBase 的工作流是内置插件,不需要额外安装,开箱即用。
需求:当有人创建了一条新工单,并且指定了处理人,系统自动给处理人发一条站内消息,让他知道"有活儿来了"。
打开右上角插件配置菜单,进入 工作流管理。

点击 新建,在弹出的对话框中:

提交后,点击列表中的 配置 链接,进入流程编辑界面。
点击顶部的触发器卡片,打开配置抽屉:
数据表:选择 主数据源 / 「工单」
触发时机:选择「新增或更新数据后」
发生变动的字段:勾选「处理人(Assignee)」——只有处理人字段变了才触发,避免其他字段的修改产生不必要的通知(新增数据时,所有字段都被视为发生变动,所以新建工单也会触发)
满足以下条件才触发:模式选「满足组内任意条件」,添加两个条件:
assignee_id 不为空Assignee / ID 不为空为什么要配两个条件?因为触发时表单里可能只有外键(assignee_id)而没有查出关联对象,也可能有了关联对象但外键字段为空。两个条件用 OR 关系,确保只要指定了处理人就一定触发。
预加载关联数据:勾选「Assignee」——后续通知节点需要用到处理人的信息,必须在触发器里提前加载

点击保存。这样,触发器本身就完成了条件判断——只有处理人不为空时才触发,不需要额外添加条件判断节点。
点击触发器下方的 +,选择 通知 节点。

打开通知节点的配置,第一项就是选择 通知渠道——但我们还没有创建过渠道,下拉列表是空的。先去创建一个。

NocoBase 支持多种通知渠道类型:
| 渠道类型 | 说明 |
|---|---|
| 站内信 | 浏览器内通知,实时推送到用户的通知中心 |
| 邮件 | 通过 SMTP 发送邮件,需要配置邮件服务器 |
本教程使用最简单的 站内信 渠道:


回到工作流编辑页面,打开通知节点的配置。
通知节点有以下配置项:
新工单:{{触发数据 / 标题}}
(下一步我们去找工单地址,退出弹窗之前,记得先保存!)
/admin/camcwbox2uc/view/d8f8e122d37/filterbytk/353072988225540。将路径粘贴到配置框中,其中 filterbytk/ 后面的数字就是工单 ID——把这部分替换为触发数据的 ID 变量即可(点击变量选择器 → 触发数据 → ID)。配置后,用户在通知列表中点击该通知就能直接跳转到对应工单的详情页,同时自动标记为已读

通知发出后,处理人可以在页面右上角的 通知中心 里看到这条消息,未读的还会有红点提示。点击通知即可跳转到工单详情页查看完整信息。
场景一的完整流程只有两个节点:触发器(含条件过滤)→ 通知。简单直接。
先别急着启用——工作流提供了 手动执行 功能,可以用指定数据测试流程是否正确:
如果工单选择栏中展示的是 id,在数据源 > 数据表 > 工单 中,将 “标题” 列设置为标题字段即可
点击执行,工作流会执行并自动切换到复制的新版本

点击右上角的三个点,选择 执行历史。这个时候应该能看到我们刚才的执行记录,点击查看后,就能看到执行的细节,包括触发情况、每个节点的执行细节、参数。



点击可以跳转到目标工单页,同时通知会自动被标记为已读。

确认流程没问题后,点击右上角的 启用/停用 开关,将工作流切换为启用状态。

注意:工作流一旦被执行过(包括手动执行),就会变成只读状态(灰色),不能再编辑。如果需要修改,点击右上角的 「复制到新版本」,在新版本上继续编辑。旧版本会自动停用。

回到工单页面,创建一条新工单,记得选一个处理人。然后切换到处理人的账号登录,检查通知中心——应该能看到一条新通知。

恭喜,第一个自动化流程跑起来了!
需求:当工单状态变为"已完成"时,系统自动在"完成时间"字段填入当前时间。这样不需要手动记录,也不会忘。
如果你还没有在工单表中创建"完成时间"字段,请先到 数据表管理 → 工单 中添加一个 日期 类型的字段,命名为"完成时间"。具体步骤参考第 2 章的字段创建方法,这里不再赘述。
回到工作流管理页面,点击新建:
关于同步和异步:
- 异步:操作之后,我们可以继续做其他事情,工作流自动执行后通知我们结果
- 同步:操作之后,界面会处于等待模式,等待工作流执行完毕之后我们才能干其他事情

打开触发器配置:
这里更推荐「全局模式」并勾选相关操作,不过为了熟悉触发器和操作绑定的机制,我们先采用「局部模式」作为教学。后面大家可以自行改回全局模式。

不同于数据表事件触发器自身包含了判断条件,我们需要自己来添加条件判断节点:

我们推荐选择 「“是” 和 “否” 分别继续」,以便于后续的扩展。

这样只有状态变为"已完成"时才继续执行,变成其他状态(如"处理中")不会触发后续动作。
点击 +,选择 更新数据 节点:


工作流配好了,但"操作后事件"需要绑定到一个具体的操作按钮上才会触发。我们在工单列表的操作列中创建一个专用的"完成"按钮:
进入 UI 编辑器模式,在工单表格的操作列中,点击 「+」,选择 「更新数据」 操作按钮
点击按钮的配置项,将标题修改为 「完成」,并选择一个完成相关的小图标(如对勾图标)

配置“字段值”,设置 “状态 = 已完成”。这样用户点击按钮时,就会触发这个赋值操作。

给按钮配置 联动规则:当工单状态已经是"已完成"时,隐藏这个按钮(已完成的工单不需要再点"完成")


回到工作流管理页面,启用「工单完成自动记录时间」工作流。
然后打开一条状态为"处理中"的工单,在操作列中点击 「完成」 按钮。刷新页面后,可以看到:

是不是很方便?这就是工作流的第二种常见用法——自动更新数据。而且通过"操作后事件 + 局部模式 + 绑定按钮"的方式,我们实现了一个精确的触发机制:只有点击特定按钮才会执行工作流。
工作流跑了几次?有没有出错?NocoBase 全都帮你记着。
在工作流管理列表中,每个工作流后面都有一个 执行次数 的数字链接。点击它,可以看到每次执行的详细记录:

如果某次执行失败了,点进详情可以看到是哪个节点出了问题,以及具体的错误信息。这是调试工作流最重要的工具。

这一章我们创建了两个简单但实用的工作流:
两个工作流分别演示了两种不同的触发方式,加起来不到 10 分钟的配置量,系统就已经能自动干活了。NocoBase 还支持更多节点类型(HTTP 请求、运算、循环等),但对于入门来说,掌握这些组合就足够应对大多数场景了。
系统能自动干活了,但我们还缺一个"全局视角"——一共多少工单?哪个分类最多?每天新增多少?下一章我们用图表区块搭一个 数据仪表盘,一眼看全局。