LigerUI下frm与grid的交互

我们来实现一个效果,如果点击汇入,然后选择了数据然后点击确认之后,遍历我的grid,把第一个不为空的FEmployee塞入frm里面的BPFEmployee

我们首先需要明确,当用户点击汇入按钮并选择数据后,我们需要将选中的数据添加到grid中。在添加数据之后,我们需要检查grid中是否有数据,然后找到第一个非空的FEmployee值,并将其设置到表单的BPFEmployee字段中。

具体步骤:

在汇入数据的回调函数中(即onSelect事件),我们添加了新的行到grid中。

在添加行之后,我们遍历grid的所有行(包括新添加的行),找到第一个FEmployee不为空的行。

如果找到了这样的行,我们就将表单中的BPFEmployee设置为该行的FEmployee值,同时更新BPFEmpName(因为表单中BPFEmployee对应的文本字段是BPFEmpName,但注意我们表单中存储的是工号,显示的是姓名,所以这里需要根据实际情况处理)。

但是,在汇入数据的回调中,我们添加行后,可能还没有立即更新到grid的数据源,所以我们可以直接遍历刚刚添加的数据(即event.data)来找到第一个非空的FEmployee。

然而,在汇入数据的回调中,我们添加行时已经将行数据添加到grid中,但此时我们也可以从event.data中获取到这些数据。

修改汇入数据的onSelect事件处理函数:

原代码片段(在importData函数中):

c 复制代码
onSelect: function (event) {
let firstRowWithEmployee = null; // 用于记录第一个有业务员的行
for (var index in event.data) {
    var rowData = event.data[index];

    // 在添加行之前,检查这一行是否有FEmployee,并且我们还没有记录第一个有业务员的行
    if (!firstRowWithEmployee && rowData.FEmployee) {
        firstRowWithEmployee = rowData;
    }

    ... // 原来的添加行代码
}

// 如果找到了有业务员的行,设置到表单
if (firstRowWithEmployee) {
    const frm = liger.get("frm");
    frm.setData({
        BPFEmployee: firstRowWithEmployee.FEmployee,
        BPFEmpName: firstRowWithEmployee.FEmpName
    });
}

总结修改步骤:

在导入数据的grid列配置中添加一个隐藏列,返回业务员姓名字段(FEmpName)。

在onSelect事件中,遍历event.data,记录第一个有FEmployee的行(包括该行的FEmpName)。

在添加完所有行后,如果表单的BPFEmployee字段为空,则用第一个有业务员的行的数据设置表单的BPFEmployee和BPFEmpName。

注意:由于我们添加了隐藏列,需要确保后端返回的数据中有FEmpName字段。

由于后端返回的数据中是否有FEmpName字段取决于后端,所以我们需要和后端确认。如果后端没有返回,那么我们需要调整后端接口。

如果后端暂时无法返回,我们可以考虑另一种方式:在导入数据时,我们只获取了业务员工号(FEmployee),而没有姓名。那么我们可以通过工号去请求姓名。但是这样会增加请求次数,而且我们不知道工号对应的姓名,所以需要调用一个接口。

考虑到时间,我们假设后端在返回导入数据时,同时返回FEmpName(业务员姓名)。

如果后端无法返回,我们可以暂时不设置姓名,只设置工号,然后让用户自己通过工号去选择业务员(因为业务员字段是一个popup,用户可以选择)。但是这样体验不好。

因此,我们尽量要求后端返回业务员姓名。

这样,就可以完成我们的需求

相关推荐
钮钴禄·爱因斯晨2 分钟前
Python常见的文件操作
android·数据库·python
CPU NULL6 分钟前
Redis相关知识点总结
java·数据库·spring boot·redis·缓存
晨晖210 分钟前
Spring Boot整合Spring MVC与外部配置完整笔记
java·spring boot·后端
xhxxx22 分钟前
《深入理解 JavaScript 对象:属性命名、访问与遍历的那些细节》
前端·javascript
BBB努力学习程序设计23 分钟前
Web App开发基础知识:从零构建现代化Web应用
前端·html
BBB努力学习程序设计24 分钟前
使用Bootstrap框架搭建简单页面:快速构建现代化网站
前端·html
西洼工作室25 分钟前
CSS响应式布局全攻略
前端·css·响应式布局·栅格系统
用户938169125536027 分钟前
VUE3项目配置
前端
懒羊羊不懒@28 分钟前
【MySQL | 进阶】存储引擎
数据库·mysql
沐浴露z31 分钟前
一张思维导图理清【操作系统】
java·linux·网络