最近有个需求,就是采购订单的供应商要按照一级和二级来选,一级关联二级,二级关联供应商。之前的一级和二级都是用LovInput做的,现在想要改为messageChoice。如下图:

OAF messageChoice 关联问题

改为:

OAF messageChoice 关联问题

下面给大家介绍下我是如何实现的:

1.页面修改:

Cate1的属性改为messageChoice,如下图配置:

OAF messageChoice 关联问题

 

OAF messageChoice 关联问题

Cate1设置事件:

OAF messageChoice 关联问题

参数:

OAF messageChoice 关联问题

Cate2的属性也改为messageChoice,如下图配置:

OAF messageChoice 关联问题

 

OAF messageChoice 关联问题

设一个无参数的事件,用来刷新用:

OAF messageChoice 关联问题

2.在页面关联的AM中,加入如下两个方法:

 

 1 public void msgChoice(String zReqLineId)
 2   {
 3     ZReqLinesVOImpl linesVO = this.getZReqLinesVO();
 4     int rowCount = linesVO.getRowCount(); 
 5     for (int i = 0; i < rowCount; i ++)
 6     {
 7       ZReqLinesVORowImpl linesRow = (ZReqLinesVORowImpl)linesVO.getRowAtRangeIndex(i);
 8 //循环遍历各行
 9       Number primaryKey = linesRow.getZreqLineId();//获取行id
10       if (primaryKey.intValue() == Integer.parseInt(zReqLineId))
11       {
12         String cate1 = (String)linesRow.getCate1();
13         System.out.println("cate1:" + cate1);
14         msgChange(cate1);
15       }
16     }
17     
18   }
19 
20   public void msgChange(String cate1)
21   {
22     ViewObject  vo = this.getCuxPOCategory2LovVO1();
23     String whareString="1=1";
24     whareString = whareString + " and DETL_PID = '" + cate1 + "'";
25     vo.setWhereClause(null);//置空VO中的where条件
26     vo.setWhereClauseParams(null); //置空VO中的where条件
27     vo.setWhereClause(whareString);//赋值拼接的where条件
28     vo.executeQuery();  //执行查询
29   }
View Code

相关文章: