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

一个表格左侧有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. MySQL Crash Course #17# Chapter 25. 触发器(Trigger)

    推荐看这篇mysql 利用触发器(Trigger)让代码更简单 以及 23.3.1 Trigger Syntax and Examples 感觉有点像 Spring 里的 AOP 我们为什么需要触发器 ...

  2. Python学习笔记之在Python中实现单例模式

    有些时候你的项目中难免需要一些全局唯一的对象,这些对象大多是一些工具性的东西,在Python中实现单例模式并不是什么难事.以下总结几种方法: 使用类装饰器 使用装饰器实现单例类的时候,类本身并不知道自 ...

  3. Cocos 开发笔记

    经发现: cocos creator 提供的hello world 模版中.只有HelloWorkd.js中 properties 属性 text的值不是'hello world!' Label 组件 ...

  4. Python3基础 input 输入浮点数,整数,字符串

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  5. Python3基础 file open 打开txt文件并打印出全文

             Python : 3.7.0          OS : Ubuntu 18.04.1 LTS         IDE : PyCharm 2018.2.4       Conda ...

  6. 嵌入式C语言--面试题

    C语言测试是招聘嵌入式系统程序员过程中必须而且有效的方法.这些年,我既参加也组织了许多这种测试,在这过程中我意识到这些测试能为带面试者和被面试者提供许多有用信息,此外,撇开面试的压力不谈,这种测试也是 ...

  7. ADT Bundle下载和安装

    下载官方adt集成包(即ADT Bundle)并安装. Android官方已经推出adt集成包,包含了eclipse.sdk和SDK Manager,只需解压出来,然后就能运行Eclipse. 官方集 ...

  8. 我在linux中使用的vundle 和 vimrc配置

    set nocompatible filetype off set rtp+=~/.vim/bundle/vundle/ call vundle#rc() Plugin 'gmarik/vundle' ...

  9. jquery.cookie.js中$.cookie() 使用方法

    定义:让网站服务器把少量数据储存到客户端的硬盘或内存,从客户端的硬盘读取数据的一种技术: 下载与引入:jquery.cookie.js基于jquery:先引入jquery,再引入:jquery.coo ...

  10. Ubuntu 14.04 下 安装Protocol Buffers

    参考: Protocol Buffers - Google's data interchange format Ubuntu 14.04 下 安装Protocol Buffers 环境 Ubuntu ...