如何解决Oracle Apex中两个页面之间的动态操作 解决方案
我的oracle apex应用程序中有两个多面搜索页面。我想创建一个动态动作,这样,如果我在一个页面中选择了一个构面,那么它也应该在另一页面中也被自动选择。我该怎么做?
解决方法
这是与浏览器localStorage一起使用DA的一种可能的解决方案。
让我警告您,此解决方案不适用于多项选择搜索(例如复选框等)。另外,您还应该确保浏览器支持本地存储。
解决方案
首先创建两个页面,将其称为 SECOND 和 THIRD (默认情况下,首页是第一页)。这两个页面都有一个分面搜索,其分面称为P X _DEPTNO,可按部门过滤记录。
在 SECOND 页面上,创建两个具有以下规格的DA:
-
第一个DA
- 名称:设置数据
- 事件:页面加载
- 创建一个True操作,类型应为:执行JavaScript代码
- 代码:
var myStorage; if ( apex.storage.hasLocalStorageSupport() ) { myStorage = apex.storage.getScopedLocalStorage({ prefix: "FSearch" }); apex.item("P2_DEPTNO").setValue(myStorage.getItem("DEPTNO")); }
-
第二个DA
- 名称:存储数据
- 事件:页面卸载
- 创建一个True操作,类型应为:执行JavaScript代码
- 代码:
var myStorage; if ( apex.storage.hasLocalStorageSupport() ) { myStorage = apex.storage.getScopedLocalStorage({ prefix: "FSearch" }); myStorage.setItem( "DEPTNO",$v("P2_DEPTNO") ); }
现在在 THIRD 页面上,创建两个相似的DA:
-
第一个DA
- 名称:设置数据
- 事件:页面加载
- 创建一个True操作,类型应为:执行JavaScript代码
- 代码:
var myStorage; if ( apex.storage.hasLocalStorageSupport() ) { myStorage = apex.storage.getScopedLocalStorage({ prefix: "FSearch" }); apex.item("P3_DEPTNO").setValue(myStorage.getItem("DEPTNO")); }
-
第二个DA
- 名称:存储数据
- 事件:页面卸载
- 创建一个True操作,类型应为:执行JavaScript代码
- 代码:
var myStorage; if ( apex.storage.hasLocalStorageSupport() ) { myStorage = apex.storage.getScopedLocalStorage({ prefix: "FSearch" }); myStorage.setItem( "DEPTNO",$v("P3_DEPTNO") ); }
这是一个示例,您还可以选择另一种存储方法(可能是更好的解决方案),例如Cookie或会话存储,但这取决于您。
由于有很多重复的代码,因此也考虑创建JS库。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。