介绍

表单上某个关联选择字段,在选择前,过滤掉列表上已经有的数据,目标功能弹出框只显示未选择过的数据

详细步骤

1.注册关联选择字段的“选择前”事件

2.编写代码

相关代码

const {
    $func, // 功能对象
    field, // 字段详细配置
    model, // 表单数据
    type,  // 类型:column(列表字段)|form(表单字段)
    $form, // 功能表单对象(表单编辑起效)
    $grid, // 功能列表对象(列表编辑起效)
    options,// 查询配置项,可以根据业务进行调整
} = EventOptions;

//查询当前列表显示的数据,这里还加了表单字段的作为条件进行了过滤
const data = JE.syncAjax({
    url:'/je/common/load',
    params: {
        tableCode:"JE_DEMO_FUNC",
        funcCode:"JE_DEMO_FUNC",
        j_query:'[{"type":"=","code":"FUNC_MC","value":"测试","cn":"and"}]'

    },
    headers: {pd:"test"}
});

//查看数据,数据存在之后,对弹窗出的数据进行过滤
if(data.success){
    const gysnames = [];
    data.data.rows.map(function(row) {
        //在这里获取功能中选择的数据push到空数组里面,这里建议用ID
        row.FUNC_GYSMC && gysnames.push(row.FUNC_GYSMC);
    });
    options.querys=[{"type":"notIn","code":"GYS_GYSMC","value":gysnames,"cn":"and"}];
}
return true;
最后编辑: 呼丽华  文档更新时间: 2025-01-15 16:00   作者:呼丽华