当前位置: 首页 > news >正文

泛微E10自定义“批准”按钮点击事件 —— 拦截逻辑实战分享

泛微E10自定义“批准”按钮点击事件 —— 拦截逻辑实战分享

在日常使用泛微E10系统进行流程开发时,我们常常需要对系统默认按钮(如“批准”按钮)添加自定义拦截逻辑,以便在用户执行某些关键操作前进行二次确认,确保业务流程的严谨性和可控性。

本文将分享如何通过泛微提供的 getFlowPageSDKregisterInterceptEvent 接口,复写“批准”按钮的默认行为,加入一个自定义确认弹窗,实现对PO生成的二次确认拦截逻辑。


💡 场景说明

在某个流程节点中,当用户点击“批准(AGREE)”按钮时,系统会根据业务规则自动生成PO(采购订单)。但一旦PO生成后,BOQ(工程量清单)将不可修改。

因此,我们希望在用户点击“批准”按钮时弹出确认框,提示用户该操作的后果,并由用户确认是否继续执行。


🧩 实现思路

我们借助泛微的前端SDK能力:

  • 通过 window.weappWorkflow.getFlowPageSDK() 获取流程页面SDK实例;
  • 使用 registerInterceptEvent 拦截“批准”按钮点击事件;
  • 弹出自定义确认框(showConfirm);
  • 用户点击“确认”后调用 successFn() 正式触发“批准”逻辑;
  • 用户点击“取消”后调用 failFn() 阻止操作继续执行。

🛠️ 示例代码

// 获取流程页面SDK实例
const wffpSdk = window.weappWorkflow.getFlowPageSDK();
const params = wffpSdk.getBaseParam();  // 可获取当前流程信息// 获取表单SDK(如需操作表单可使用)
const formSdk = window.WeFormSDK.getWeFormInstance();// 注册SDK准备就绪事件
wffpSdk.ready(() => {// 拦截“批准”按钮点击事件(menutype 为 AGREE)wffpSdk.registerInterceptEvent('BeforeClickOperBtn|AGREE', (successFn, failFn, params) => {// 弹出确认框wffpSdk.showConfirm("If work order generated, the BOQ can't be modified. Confirm to generate the PO?",function() {// 用户点击“确定”后,继续执行默认行为successFn();},function() {// 用户点击“取消”后,中止操作failFn();},{title: "Information Confirmation", // 弹窗标题(仅PC端有效)okText: "Ok",                       // 确认按钮文字cancelText: "Cancel"               // 取消按钮文字});});
});

✅ 效果预览
• 点击“批准”按钮后,弹出如下确认框:

Information Confirmation
If work order generated, the BOQ can’t be modified. Confirm to generate the PO?
[Ok] [Cancel]

•	用户点击 Ok:进入正常审批流程;
•	用户点击 Cancel:取消此次操作,无任何流程变更。

📌 注意事项
menutype 值需与按钮类型精确匹配,例如“批准”对应的是 AGREE;
showConfirm 弹窗API目前仅在 PC端支持标题(title)配置项;
• 可扩展逻辑判断,如根据表单字段或流程状态动态控制是否弹出确认框;
• 若需要兼容移动端,建议搭配其他提示机制如 showToast 做兜底提示。

🧭 总结

通过本案例,我们成功地实现了对泛微E10系统“批准”按钮行为的前端拦截,加入了自定义交互提示,有效降低误操作风险,为企业流程系统的稳定运行保驾护航。

相关文章:

  • Agent2Agent(A2A)开放协议:构建智能代理协同生态的标准架构
  • 动态规划 -- 简单多状态dp,打家劫舍问题
  • 身份认证C#集成方案-数字时代身份证实名认证利器
  • 大模型时代的机遇与挑战
  • iso17025证书申请方法?iso17025认证意义
  • 数据库子查询
  • C++实习工程师简历模板
  • 【口腔粘膜鳞状细胞癌】文献阅读3
  • 【深度学习】计算机视觉(15)——ViT理解与应用
  • pidstat指令分析
  • 《卷积神经网络(CNN):深度学习中的图像识别利器》
  • 解决fastJson JSON.parseArray方法 非法字符问题
  • e实例性能测评:Intel Xeon Platinum处理器,经济型入门级服务器
  • 基于爱—特的未来的时空奇点压缩爆炸
  • 【限流算法】计数器、漏桶、令牌桶算法
  • 高精度--
  • ArcPy工具箱制作(上)
  • Vue王炸打包工具新作品 Tsdown上线
  • Java Collection(8)——Map的遍历方式
  • LLM做逻辑推理题 - 拥有古物的是谁?
  • 俄乌战火不熄,特朗普在梵蒂冈与泽连斯基会晤后口风突变
  • 早睡1小时,变化有多惊人?第一个就没想到
  • 科学时代重读“老子”的意义——对谈《老子智慧八十一讲》
  • 朝鲜证实出兵俄罗斯协助收复库尔斯克
  • 央媒关注给保洁人员设休息室:让每一份踏实奋斗得到尊重呵护
  • 哈马斯同意释放剩余所有以方被扣押人员,以换取停火五年