zoukankan      html  css  js  c++  java
  • 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.
  • 相关阅读:
    交通综合改造工程EPC总承包项目
    二三维一体化地理信息平台
    NetCore3.1升级到Net5.0序列化方法过时问题
    windows server2012部署.net core IIS,页面报503,应用程序池自动停止。。。
    NetCore使用NPOI导入Word中的图片信息
    NetCore 使用 iTextSharp 读取 PDF 中的文字信息
    NetCore 在 Docker中文件路径找不到的问题
    Vue中数组list直接push的是对象而不是追加数据的问题
    netcore3.1增加阿里云OSS云存储服务
    Centos中Docker容器中程序访问宿主机Redis和Mysql
  • 原文地址:https://www.cnblogs.com/huanghongbo/p/4511312.html
Copyright © 2011-2022 走看看