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,用户可以选择)。但是这样体验不好。

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

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

相关推荐
CQU_JIAKE2 分钟前
4.17[Q]
java·linux·服务器
2301_815279524 分钟前
CSS定位如何实现多行文字垂直居中_通过绝对定位模拟表格
jvm·数据库·python
m0_684501988 分钟前
C#怎么使用LINQ Contains包含判断 C#如何用Contains实现类似SQL IN查询的集合包含判断【语法】
jvm·数据库·python
2301_7641505625 分钟前
c++如何读取和解析带BOM头的UTF-8与UTF-16文本流【详解】
jvm·数据库·python
qq_4240985629 分钟前
HTML函数开发用窄边框笔记本有优势吗_便携与性能权衡【指南】
jvm·数据库·python
Wyz2012102432 分钟前
CSS如何实现导航栏下划线随鼠标移动_利用-hover伪类与过渡动画控制
jvm·数据库·python
Hooray32 分钟前
为了在 Vue 项目里用上想要的 React 组件,我写了这个 skill
前端·ai编程
2201_7610405933 分钟前
SQL如何统计每个用户的首次行为时间_MIN聚合与分组
jvm·数据库·python
咸鱼翻身了么34 分钟前
模仿ai数据流 开箱即用
前端
风花雪月_34 分钟前
🔥IntersectionObserver:前端性能优化的“隐形监工”
前端