在开发中,我们遇到以下一个需求。

一个表格左侧有5列是固定存在的,右侧有N列是动态生成的,并且该N列中第一列可输入,第二列是不可编辑的,但是是数字,如果小于0,那么就要显示为红色,重点标识出来。

首先,我们假设你的VO中的SQL查询已经做好了,并且每次能动态确定到需要插入几列。

//获得你要生成的列总数
int n=Integer.valueOf(String.valueOf(am.invokeMethod("getCloumnCount"))) ;
OATableBean tableBean = (OATableBean)webBean.findChildRecursive("tableRN");
//创建第1个动态列列单元格
//createWebBean有很多参数,有兴趣的可以翻一翻官方文档
OAMessageTextInputBean cellOneBean= (OAMessageTextInputBean)this.createWebBean(pageContext,
OAMessageTextInputBean.MESSAGE_TEXT_INPUT_BEAN,
null,
"Cell1"
);
cellOneBean.setViewUsageName("XxxxVO1");//此列绑定的VO
cellOneBean.setViewAttributeName("prodType1");//此列绑定的VO中的字段
cellOneBean.setLabel("第1个动态单元格"); //此列需要显示的题头 //DisableFlag是你在VO中的叫DisableFlag的字段,根据某些条件在VORowImpl中返回true或者false
//其用法类似于在页面上设置某个组件的属性 Disable = ${oa.current.DisabledFlag}
OADataBoundValueViewObject Disabled = new OADataBoundValueViewObject(cellOneBean,"DiabledFlag");
cellOneBean.setAttributeValue(this.DISABLED_ATTR,Disabled); tableBean.addIndexedChild(cellOneBean); //创建第2个动态列单元格
OAMessageStyledTextBean cellTwoBean =
(OAMessageStyledTextBean)this.createWebBean(pageContext,
OAMessageStyledTextBean.MESSAGE_STYLED_TEXT_BEAN,
null,
"Cell2"
); cellTwoBean.setViewUsageName("XxxxVO1");//此列绑定的VO
cellTwoBean.setViewAttributeName("prodType2");//此列绑定的VO中的字段
cellTwoBean.setLabel("第2个动态单元格"); //此列需要显示的题头 //同上,CssCode为VO的一个字段
/*其VORowImpl中的写法类似于
public String getCssCode()
{
//return (String) getAttributeInternal(CSSCODE);
// return CSS
if( this.getScore() != null && this.getScore().floatValue() < 0 )
{
//OAF的CSS样式的设定请参考其他资料
return "TouchScreenRedDataText";
}else
{
return "";
} } */
OADataBoundValueViewObject cssjob = new OADataBoundValueViewObject(cellTwoBean,"CssCode");
cellTwoBean.setAttributeValue(oracle.cabo.ui.UIConstants.STYLE_CLASS_ATTR, cssjob); tableBean.addIndexedChild(cellTwoBean); for(int i=3; i<n+1; i++ ){
//动态创建WebBean
OAMessageStyledTextBean summary =
(OAMessageStyledTextBean)this.createWebBean(pageContext,
OAMessageStyledTextBean.MESSAGE_STYLED_TEXT_BEAN,
null,
"Text" + i
); String label = null;
label = "Prodtype" + i;
//从AccountCostDetailVO中显示对应到的数据项到动态的webBean
summary.setViewUsageName("AccountCostDetailVO");
summary.setViewAttributeName(label);
summary.setLabel("第"+i+"个动态单元格"); tableBean.addIndexedChild(summary);
}

为动态创建的组件添加FireAction事件

// 启用Expense Template的FireAction功能
OAMessageChoiceBean choiceBean = (OAMessageChoiceBean)webBean.findChildRecursive("ExpenseTemplate");
choiceBean.setFireActionForSubmit("change", null, null, true);
        OACellFormatBean createApproveCellBean =(OACellFormatBean)this.createWebBean(pageContext , OAWebBeanConstants.CELL_FORMAT_BEAN , null , null);

        OAButtonBean hierarchBean =
(OAButtonBean)createWebBean(pageContext , OAWebBeanConstants.BUTTON_BEAN , null , null);
hierarchBean.setID("CuxHierarySumbitBtn");
hierarchBean.setName("CuxHierarySumbitBtn");
String hierarchy = pageContext.getMessage("CUX" , "CUX_APPROVAL_HIERARCHY" , null);
hierarchBean.setLabel(hierarchy);
hierarchBean.setText(hierarchy);
hierarchBean.setFireActionForSubmit("CuxHieraryEvent" , null , null , true);
createApproveCellBean.addIndexedChild(hierarchBean); OARowLayoutBean btnRowBean =(OARowLayoutBean)webBean.findChildRecursive("ButtonBarRow");
btnRowBean.addIndexedChild(createApproveCellBean);

为table中的bean组件添加事件,并在事件处理中可以获取当前行的参数

import java.util.HashTable;

Hashtable params = new Hashtable();
params.put("param_AucHeaderId" , new OADataBoundValueViewObject(attrBidValueBean , "AuctionHeaderId"));
params.put("param_BidNumber" , new OADataBoundValueViewObject(attrBidValueBean , "BidNumber"));
params.put("param_LineNumber" , new OADataBoundValueViewObject(attrBidValueBean , "LineNumber"));
params.put("param_SequenceNumber" , new OADataBoundValueViewObject(attrBidValueBean , "SequenceNumber")); attrBidValueBean.setFireActionForSubmit("AttrBidValueNumEvent" , null , params , false , false);

或者创建事件后,在PFR中使用获取事件行的方式去获得当前行的列值

//注:动态创建的不能以EVENT_SOURCE_ROW_REFERENCE方法来获取当前行。

 String rowRef = pageContext.getParameter(EVENT_SOURCE_ROW_REFERENCE);
Row currentRow = am.findRowByRef(rowRef);
currentrow5.getAttribute("Sscore");

现在TABLE里面的每行都有一个poplist,用的相同的VO,但是要求每行的下拉框中的值根据当前行的某些值来获取。

OATableBean table = (OATableBean)webBean.findChildRecursive("TableRN");;
OAMessageChoiceBean statsfiedBean =
(OAMessageChoiceBean)webBean.findChildRecursive("InstallmentName"); if (statsfiedBean != null) {
statsfiedBean.setPickListCacheEnabled(false);
statsfiedBean.setListVOBoundContainerColumn(0, table,
"ProjectName" /* ProjectName 是TableRN中的组件ID,而不是TableRN对应的VO中的attribute*/
); }
//OAF JAVA DOC标准示例

OATableBean table = ...
OAMessageChoiceBean empPoplist =
(OAMessageChoiceBean)table.findChildRecursive("EmpName");
empPoplist.setListVOBoundContainerColumn(0, /* bind index */
table,"Deptno" /* Deptno是table中的组件ID,而不是table对应的VO中的attribute*/ );

参考资料:

EBS OAF开发中的绑定值(BoundValues)

EBS OAF开发DataBoundValues的使用示例-动态显示表列的左右对齐

            

OAF 动态创建组件以及动态绑定属性的更多相关文章

  1. Angular动态创建组件之Portals

    这篇文章主要介绍使用Angular api 和 CDK Portals两种方式实现动态创建组件,另外还会讲一些跟它相关的知识点,如:Angular多级依赖注入.ViewContainerRef,Por ...

  2. 动态创建组件TEdit

    //动态创建组件TEdit procedure TForm1.FormMouseDown(Sender: TObject; Button: TMouseButton;  Shift: TShiftSt ...

  3. Delphi动态创建组件,并释放内存

    开发所用delphi版本是xe2,效果图如下: 代码如下: ---------------------------------------------------------------------- ...

  4. Vue动态创建组件方法

    组件写好之后有的时候需要动态创建组件.例如: 编辑文章页面,正文是一个富文本编辑器,富文本编辑器是一个第三方的组件,点击添加章节的时候需要动态的创建一个富文本编辑器这个时候怎么处理呢. 富文本编辑器也 ...

  5. angular4 动态创建组件 vs 动态创建模板

    实现  模拟场景:页面上"帮助"按钮的点击触发帮助文档的弹出框,且每个页面的帮助文档不一样 因此弹出框里的帮助文档是一个动态模板而不是动态组件 以下comp均代表Type类型的动态 ...

  6. Delphi 动态创建组件,单个创建、单个销毁

    效果图如下: 实现部分代码如下: var rec: Integer = 0; //记录增行按钮点击次数 implementation {$R *.dfm} //动态释放单个组件内存,即销毁组件 pro ...

  7. ExtJS动态创建组件

    J是代码动态创建dom: 或者 eval有后台组织代码,前台执 ======================= ExtJS组件的动态的创建: 程序中大多数时候需要在后台根据业务逻辑创建符合要求的组件, ...

  8. oaf 动态创建table vo (转)

    原文地址:如何动态创建table 需求: 因为系统中有几千个QA plan 但是不能手动创建几千个 质量收集页面所有需要根据 不同的plan 动态创建对应的 质量收集页面. 但是创建tabel 都要绑 ...

  9. vue 动态创建组件(运行时创建组件)

    function mountCmp (cmp, props, parent) { if (cmp.default) { cmp = cmp.default } cmp = Vue.extend(cmp ...

随机推荐

  1. P3456 [POI2007]GRZ-Ridges and Valleys(bfs)

    P3456 [POI2007]GRZ-Ridges and Valleys 八个方向都跑一遍bfs,顺便判断一下是山峰还是山谷,或者是山坡(俩都不是) (实在不知道要说啥了qwq) #include& ...

  2. Quartz框架调用Demo

    Quartz框架调用Demo 任务调度在JAVA应用程序中运用的十分普遍,掌握QUARTZ是必备的技能; 官网:http://www.quartz-scheduler.org/ 下载最新1.80资源包 ...

  3. Js/html格式化在线工具

    Js/html格式化在线工具 Js/html格式化在线工具:http://tool.chinaz.com/Tools/jsformat.aspx

  4. Nodejs学习笔记(四)与MySQL交互(felixge/node-mysql)

    原文链接:http://www.cnblogs.com/zhongweiv/p/nodejs_mysql.html 介绍使用felixge/node-mysql进行SQL的增删改查以及断线重连等操作.

  5. 使用dll,将image库开放出去

    这是很经典的想法了,但是如何来做,不经过摸索不知道细节.   最简单: dll处   #include "stdafx.h"   #ifdef _DEBUG #define new ...

  6. FJNUOJ the greed of Yehan(最长路 + 权值乘积转化)题解

    Description During the trip, Yehan and Linlin pass a cave, and there is a board at the door, which s ...

  7. mybatis的注解开发之三种动态sql

    脚本sql XML配置方式的动态SQL我就不讲了,有兴趣可以自己了解,下面是用<script>的方式把它照搬过来,用注解来实现.适用于xml配置转换到注解配置 @Select(" ...

  8. java 监控工具 jconsole

    如图

  9. flink架构介绍

    前言 flink作为基于流的大数据计算引擎,可以说在大数据领域的红人,下面对flink-1.7的架构进行逻辑上的分析并和spark做了一些关键点的对比. 架构 如图1,flink架构分为3个部分,cl ...

  10. js中拼接HTML方式方法及注意事项

    博主原创:未经博主允许,不得转载 在前端应用中,经常需要在js中动态拼接HTML页面,比如应用ajax进行局部刷新的时候,就需要在js中拼接HTML页面. 主要规则是将HTML页面的标签拼接为标签字符 ...