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

    <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.
  • 相关阅读:
    DriveInfo 类 提供对有关驱动器的信息的访问
    遍历数组 例子
    怎么判断点击dataGridView1的是第几列
    无法加载协定为“ServiceReference1.LanguageService”的终结点配置部分,因为找到了该协定的多个终结点配置。请按名称指示首选的终结点配置部分。
    c#面试题及答案(一)
    SQL杂谈 ,有你想要的...
    TextView和Button的学习
    GitHub的学习和使用
    App的布局管理
    EditText制作简单的登录界面
  • 原文地址:https://www.cnblogs.com/huanghongbo/p/4511312.html
Copyright © 2020-2023  润新知