ADF11g-038: 让PanelTabbed组件在页面刷新时保持当前打开的项
2014-03-20 14:36
218 查看
概述
在ADF开发中,我们发现PanelTabbed组件在页面刷新时会回到第一个Tab项,然而这可能并不是我们想要的结果。分析
通过观察我们很容易发现,控制ShowDetailItem打开的属性就是disclosed。那么我们只要在选择Tab项的时候动态的设置disclosed属性,并且把这个状态保留下来,即可达到刷新页面的时候不会出现前文所描述的情况。如何动态的设置disclosed的属性呢,继续观察,我们发现ShowDetailItem中还有个disclosureListener属性。这个监听方法会执行两次,第一次是关闭上一个Tab页,第二次则是打开现在的Tab页,我们只要捕捉到现在打开的这个Tab页,保存下来就好了。
具体实现参照代码。
代码
ShowDetailItemBean.javapublic class ShowDetailItemBean implements Serializable { private static final ADFLogger logger = ADFLogger.createADFLogger(ShowDetailItemBean.class); private String expandedItemId; public ShowDetailItemBean() { super(); } public void onDisclosure(DisclosureEvent event) { boolean isExpanded = event.isExpanded(); if(isExpanded) { String id = event.getComponent().getId(); setExpandedItemId(id); logger.info("Expended item id : " + id); } } public void setExpandedItemId(String expandedItemId) { this.expandedItemId = expandedItemId; } public String getExpandedItemId() { return expandedItemId; } }
页面设置,disclosureListener,disclosed
<af:showDetailItem text="showDetailItem 1" id="sdi1" disclosureListener="#{pageFlowScope.panelTabbedItemBean.onDisclosure}" disclosed="#{pageFlowScope.panelTabbedItemBean.expandedItemId == 'sdi1'}"> <af:commandButton text="commandButton 1" id="cb1"/> </af:showDetailItem>
相关文章推荐
- 让PanelTabbed组件在页面刷新时保持当前打开的项
- 刷新当前页面,保持原有数据
- 解决element-ui中el-menu组件作为vue-router模式在刷新页面后default-active属性与当前路由页面不一致问题的方法
- 如何使a标签打开新页面并阻止刷新当前页面
- 关于showmodaldialog 打开新窗口后提交表单操作时,避免弹出新窗口和避免从后台获取“新数据”后不能刷新当前模态页面的解决方案
- X5用组件windowRunner打开后 再点数据打开页面获取值不会刷新 的解决办法
- 怎么判断页面是第一次打开还是刷新!
- php刷新当前页面
- JS怎么刷新当前页面
- 如何使得ShowModalDialog打开的页面自动刷新
- WebBrowser 在当前窗体打开新的页面
- 打开一个页面,返回主页面,刷新本页面
- showModalDialog打开的页面需要跳转或刷新
- 判断当前页面是刷新还是关闭
- JS刷新当前页面
- 刷新父页面(window.open打开的页面)
- 打开新窗口关闭当前页面不弹出关闭提示js代码
- iframe下刷新页面无法刷新当前页面的解决办法
- 如何刷新其他页面(非当前页面)的框架页
- 页面刷新,保持页面位置