OAF 小知识

打开新窗口链接地址

1.link的动态使用

  link组件有一个属性叫 Target Frame,设置为_blank就可以新开窗口

  link组件默认是打开当前系统中的连接地址,如果要打开外部网页,可以在Distination URI里面使用http://,如http://www.baidu.com

  如果此link是在table中,每行的地址都不一样,那么使用http://{@linkSite}使用这个动态传入参数就行了。

2.如果需要被打开的新窗口连接地址逻辑太复杂,那么可以使用rawText,然后绑定vo。

在AM中取得message等系统定义的内容,通过this.getOADBTransaction()来获取,例如

this.getOADBTransaction().getMessage("","",null);
this.getOADBTransaction().getSequenceValue("");
this.getOADBTransaction().getProfile("");
this.getOADBTransaction().getUserId();
this.getOADBTransaction().getUserName();
this.getOADBTransaction().getCurrentDBDate();
this.getOADBTransaction().getCurrentLanguage();
this.getOADBTransaction().getCurrentUserDate();
……
this.getOADBTransaction().getCurrentDBDate();的类型为oracle.jbo.domain.Date。
pageContext.getCurrentDBDate()的类型为java.util.Date。

3.关于  row.setNewRowState(Row.STATUS_INITIALIZED);

此方法会将当前新增的行设为初始状态,若添加之后未在此行做任意操作即跳转到其他页面,则再返回该页面会发现此行会消失。

  

4. 通过LOV返回到基于EO的VO,

  通过LOV返回的值在页面上如果是一个disabled或者readonly,例如返回一个messageStyledText,则此值仅仅会插入VO,而不会插入EO。

5. 在AM中设置多组织访问。

OAF 小知识

<Properties>
<Property Name ="MULTIORG_ENABLED" Value ="M" />
</Properties>

6.OAF中加密解密参数

  加密传参

        mappingId = pageContext.getParameter("mappingId");
paramMappingId = pageContext.encrypt((String)mappingId); ((HashMap)localObject3).put("mappingId", paramMappingId);

  解密参数

if (paramOAPageContext.getParameter("mappingId") != null)
{
localObject3 = paramOAPageContext.getParameter("mappingId");
str9 = paramOAPageContext.decrypt((String)localObject3);
paramOAPageContext.putTransactionValue("mappingId", str9);
}
else if (paramOAPageContext.getTransactionValue("mappingId") != null)
{
str9 = (String)paramOAPageContext.getTransactionValue("mappingId");
}

参考:EBS OAF 开发中 URL中的标记、加密和编码

7.若基于EO中的VO  有一个calculate的列的别名与EO中字段的名称一模一样,那么会被认为是数据库列,在从EO往数据库插入数据的时候,会去进行校验,容易造成数据不一致的错误。

会抛出事务处理异常的错误。

8. 控制hideshowheader的方法

String hideShowEvent = pageContext.getParameter(OAWebBeanConstants.EVENT_PARAM);
    System.out.println("region7="+pageContext.getParameter("region7")+","+hideShowEvent);
    if (OAWebBeanConstants.SHOW_EVENT.equals(hideShowEvent))
    { 
              //your code

}

9.messageStyledText 设置 No Wrap  为true  不换行

10.

查询结果显示总数而不是更多,

例如直接显示为 1-10/16

设置VO->Tuning->  All at Once

11.

QueryTable里面客户化查询

 OAQueryBean querybean = (OAQueryBean)webBean.findIndexedChildRecursive("QueryRN");
// 判断用户是否选择了查询按钮
if (pageContext.getParameter(querybean.getGoButtonName()) != null)
{

}

 
12.
在定义的VO SQL中若使用:1这种方式使用变量,Binding Style请使用Oracl Positional.
上一篇:修改Python文件日志输出位置


下一篇:MAC Java 开发环境配置