OAF 小知识[转]

转自:http://www.cnblogs.com/huanghongbo/p/4511312.html

打开新窗口链接地址

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中设置多组织访问。


     
  



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.
参考资料: Oracle EBS OAF(ADF) VO(View Object)开发中的绑定方式(Binding Style)的介绍
请使用浏览器的分享功能分享到微信等