JeecgBoot项目中子表字段变化触发主表更新的JS增强实现
2025-05-02 12:58:52作者:齐冠琰
问题背景
在JeecgBoot项目的Online表单开发中,开发者经常需要实现子表字段变化时自动更新主表相关字段的功能。这种场景在财务系统、报销单据等业务中非常常见,比如子表金额汇总后更新到主表总金额字段。
核心实现方案
通过JS增强功能,可以监听子表字段变化并触发主表更新。以下是实现这一功能的关键代码示例:
daily_costs_details_onlChange(){
return {
total_amount(){
let total = 0
this.getSubTableInstance('daily_costs_details').getValues((err,values)=>{
if(values && values.length>0){
for(let item of values){
total += item.total_amount;
}
}
this.triggleChangeValues({reim_amount: total})
})
}
}
}
实现要点解析
-
命名规范:JeecgBoot中字段名使用常规命名即可,不需要强制转换为驼峰式命名。保持与数据库字段一致的下划线命名方式完全可行。
-
事件监听:通过
onlChange方法监听子表字段变化,这里监听的是子表daily_costs_details中的total_amount字段。 -
数据获取:使用
getSubTableInstance获取子表实例,然后调用getValues方法获取子表所有数据。 -
计算逻辑:遍历子表数据,累加
total_amount字段值。 -
主表更新:通过
triggleChangeValues方法触发主表reim_amount字段的更新。
常见问题排查
-
事件未触发:检查子表字段名是否完全匹配,包括大小写和下划线。
-
主表未更新:
- 确认主表字段
reim_amount是否存在且可编辑 - 检查是否有其他JS代码覆盖了该字段的行为
- 使用
debugger语句调试确认代码执行路径
- 确认主表字段
-
数据计算错误:
- 确保子表数据已正确加载
- 检查
total_amount字段值是否为有效数字 - 处理可能的空值或非数字情况
最佳实践建议
-
添加数据校验:在累加前应验证字段值是否为有效数字,避免NaN情况。
-
性能优化:对于大型子表,考虑使用reduce方法替代for循环。
-
错误处理:完善错误处理逻辑,特别是getValues方法的回调中err参数的处理。
-
状态管理:考虑添加加载状态,避免用户频繁操作导致的计算冲突。
通过以上实现方案和注意事项,开发者可以可靠地在JeecgBoot项目中实现子表字段变化触发主表更新的功能,满足各种业务场景的需求。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0214
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
469
465
暂无描述
Dockerfile
778
5.08 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
877
2.03 K
Ascend Extension for PyTorch
Python
758
968
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
697
1.4 K
昇腾LLM分布式训练框架
Python
185
231
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.1 K
1.14 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.25 K
677