博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Form开发中组件控制的几个常用方法
阅读量:6568 次
发布时间:2019-06-24

本文共 3315 字,大约阅读时间需要 11 分钟。

在Oracle EBS 的Form二次开发中,经常需要灵活的来控制某些组件是否可用、是否可见;有时希望某些字段的值自动生成或者手动输入;有时又希望能够根据不同的职责、不同的用户等来设置不同的行为控制。常见的需求:

  1. 只有某些角色的人才能看到销售订单中“登记订单”这个按钮
  2. 只有某些角色的人才可以切换到某个标签页
  3. 实现订单号码根据需要自动生成编号或者手工录入
  4. 快速编码的值即可以录入所有应用下的,也可以只能录入某个应用,更可以只能录入某个应用下某个类型下的值
  5. 在某些情况下Form需要只能够查询
  6. ……

在Oracle EBS环境中有很多方法来实现这些功能,但是使用预置文件(Profile)子功能(Subfunction)功能参数(Function Parameter)是最常用最方便有效的3种方式,

 

一,子功能(Subfunction)

子功能是实际上是一个特殊的功能,利用子功能的方式其实就是使用了Oracle EBS的功能权限控制来实现安全性的控制,其实质就是某个用户能够执行一个被授权的功能,一般情况下会使用子功能来控制某些按钮是否显示,进而实现了用户是否可以操作Form中的某些功能,所以Oracle EBS的开发人员经常使用子功能来通过显示/隐藏或者有效/失效界面上的组件来实现功能的有效或无效,如上面常见需求中的1,2使用子功能最适合。

如下我希望只有授权的用户才能看到Book Order这个按钮,看不到的自然也无法进行这个操作了

 

实现步骤如下:

1,为Book Order按钮组件定义一个子功能

 

2,Form代码中根据功能来控制组件

在PRE-FORM触发器中,来判断用户是否有权限看到这个操作,如果有就显示否则不显示

PLSQL
 
12345
(fnd_function.test('XHUORDER_BOOK_ORDER'))   app_item_property.set_property('headers.book_order', DISPLAYED, PROPERTY_ON);  app_item_property.set_property('headers.book_order', DISPLAYED, PROPERTY_OFF); ;

3,将子功能授权给有权的用户

如果某个用户需要显示这个按钮,只要将子功能XHUORDER_BOOK_ORDER添加用户拥有的职责对应的菜单里面,把子功能XHUORDER_BOOK_ORDER添加为一个菜单项,但是Prompt留空就可以

定义的时候需要将Prompt栏位留空,这样在菜单显示的时候就看不到这个菜单项,实际关键的是最后的Grant列,默认都是勾上的,代表了授权给相关的职责用户

 

二、功能参数

功能参数的方法实际上和子功能是一致的控制方法,都是使用功能权限来进行控制, 它通过针对同一个Form定义多个Function,不同Function参数的值不同来实现控制,Oracle EBS中最典型的应用就是Form中的仅仅查询功能和快速编码(Lookup Code)定义界面

在快速编码定义界面中,可以通过APPL_SHORT_NAME参数来控制只能查询特点应用的快速编码;LOOKUP_TYPE参数来控制特点类型的快速编码。实现了参数值不同界面的行为也不同

 

实现步骤:

1,在Form设计器中定义参数

像快速编码定义的Form中,定义了如下图的参数

2,在Form程序代码中引用参数的值来控制

根据业务需求和功能设计的要求,通过参数的值来编写代码,如下

PLSQL
 
123456789101112131415
(:parameter.lookup_type   )     set_block_property('FND_LOOKUP_TYPES', INSERT_ALLOWED,        PROPERTY_FALSE);   ;    (:parameter.appl_short_name   )     :parameter.appl_short_name := (:parameter.appl_short_name);    :parameter.appl_id :=         fnd_utilities.get_application_id(:parameter.appl_short_name);    :parameter.application :=         fnd_utilities.get_application_name(:parameter.appl_id);     app_item_property.set_property('FND_LOOKUP_TYPES.APPLICATION_NAME',        INSERT_ALLOWED, PROPERTY_OFF);   ;

parameter的参数值在Form运行的时候会从Function定义中传入

3,定义Function时设置具体的参数值

如上面显示的DEMAND_CLASS的快速编码,参数为:VIEW_APPLICATION=”AU” LOOKUP_TYPE=”DEMAND_CLASS”

为Function定义了参数,在运行的时候就会到form的parameter中去查找同名的参数,并将等号(=)后的值传给参数,多个参数间用空格隔开。因此可以采用功能参数值的不同定义不同的功能,并赋给对应用户的职责就实现了不同的控制

三、预置文件(Profile)

 

预置文件的控制是这些方法中最灵活最强大的一种方法,通过预置文件可以实现到站点层、应用层、职责层和用户层的控制,预置文件相当于Oracle EBS系统中根据的一个全局变量,这个全局变量在不同的上下文可以设置为不同的值,因此在Form的开发中可以使用它来实现业务逻辑的控制,上面列出的常见需求都可以使用预置文件的方法来实现,只是预置文件太过灵活,所以有的需求则显得大材小用,因此只要需要较灵活层次控制并符合站点层、应用层、职责层和用户层这样层次控制的时候才采用。

实现步骤:

1,定义预置文件

在Application Developer职责下定义预置文件,就像在Oracle EBS系统中定义一个变量的感觉,SQL Validation区域就是预置文件可以定义的值列表

 

2,Form中根据预置文件值进行控制

PLSQL
 
1234567
l_order_num_mode := fnd_profile.('DEMO_ORDER_NUMBER_MODE');    :parameter.order_number_mode = 'AUTOMATIC'     app_item_property.set_property('HEADERS.ORDER_NUMBER', REQUIRED,  PROPERTY_FALSE);    app_item_property.set_property('HEADERS.ORDER_NUMBER', ENTERABLE, PROPERTY_FALSE);    app_item_property.set_property('HEADERS.ORDER_NUMBER', NAVIGABLE, PROPERTY_FALSE);   ;

上面的代码代表了如果预置文件DEMO_ORDER_NUMBER_MODE的值是AUTOMATIC的话,进行ORDER_NUMBER的控制

3,设置预置文件的值

 

Form程序中根据预置文件值的不同进行了不同的控制,而预置文件的值则是根据需要进行设置

通过以上预置文件值设置的不同,Form控制的项就会根据设置的不同表现出不同的行为。

 

上面描述的3个方法是Oracle EBS Form二次开发中最常用的方法,根据功能需求的不同选择最适合的方法。

转载:

 

转载于:https://www.cnblogs.com/liuweicong39/archive/2012/06/04/2534750.html

你可能感兴趣的文章
UVa - 11400 - Lighting System Design
查看>>
Oracle 11g 客户端使用
查看>>
luvit 被忽视的lua 高性能框架(仿nodejs)
查看>>
也许每个农村出来的码农都有个田园梦
查看>>
J2EE的13种核心技术
查看>>
Express.js 中的 Sessions 如何工作?(译)
查看>>
Web自动化之Headless Chrome概览
查看>>
【133天】尚学堂高淇Java300集视频精华笔记(71-72)
查看>>
剖析 Laravel 计划任务--事件属性
查看>>
百度成立国内首个深度学习教育联盟,将制定行业标准
查看>>
Micronaut教程:如何使用基于JVM的框架构建微服务
查看>>
检查IP是否可用的方法
查看>>
互联网架构师必备技术 Docker仓库与Java应用服务动态发布那些事
查看>>
Intellij IDEA 2018.2 搭建Spring Boot 应用
查看>>
作为数据科学家,我都有哪些弱点
查看>>
(转)线程安全的CopyOnWriteArrayList介绍
查看>>
中交兴路完成7亿元A轮融资,携手蚂蚁金服共建小微物流科技服务生态
查看>>
对LinqtoExcel的扩展 【数据有限性,逻辑有效性】
查看>>
WPF TreeView HierarchicalDataTemplate
查看>>
32岁老程序员的现状和尴尬,无奈中透露些许悲凉,有选择却更痛苦
查看>>