我想启用或禁用动态仅单选项卡(而不是整个手风琴面板)。我尝试下面的方法,这里是我的代码:
的index.xhtml
<p:accordionPanel id="accordionPanelId" widgetVar="accordionPanelWidget">
<p:tab id="tab1" title="First Tab">
<h:outputText value="Contents of Tab1"/>
<h:form>
<p:commandButton value="Enable Tab2" action="#{tabBean.buttonAction}" update=":accordionPanelId:tab2"/>
</h:form>
</p:tab>
<p:tab id="tab2" title="Second Tab" disabled="#{tableBean.disableTab}">
<h:outputText value="Contents of Tab2"/>
</p:tab>
</p:accordionPanel>
tab bean.Java
@ManagedBean
@ViewScoped
public class TabBean implements Serializable {
private boolean disableTab=true;
public boolean isDisableTab() {
return disableTab;
}
public void setDisableTab(boolean disableTab) {
this.disableTab = disableTab;
}
public void buttonAction()
{
disableTab = false;
}
}
通过上述方法TAB2的内容被显示,但选项卡标题仍然冻结,可能这是不是神的方法来实现这一目标?请建议在这种方法中任何其他方式或变更。
编辑:上述方法是工作的罚款,如果我更新整个手风琴面板如下:
<p:commandButton value="Enable Tab2" action="#{tabBean.buttonAction}" update=":accordionPanelId"/>
但我不希望更新所有选项卡。
您需要将标签的disabled
属性绑定到disableTab
支持bean变量,你会在服务器端进行切换。为了反映您在服务器端所做的更改,你再Ajax的更新客户端的<p:accordionPanel/>
。使用您当前的设置,只有你需要做的是改变:
disabled
属性来支持bean变量你已经设置
<p:tab id="tab2" title="Second Tab" disabled="#{tabBean.disableTab}">
<h:outputText value="Contents of Tab2"/>
</p:tab>
<p:tab id="tab1" title="First Tab">
<h:outputText value="Contents of Tab1"/>
<h:form>
<p:commandButton value="Enable Tab2" oncomplete="accordionPanelWidget.select(2)" action="#{tabBean.buttonAction}" update=":accordionPanelId:tab2"/>
</h:form>
</p:tab>
你必须更新所有accordionPanel以启用/禁用标签。在这种情况下,你必须更新accordionPanelId。但是,您可以使用动态=“true”属性在accordionPanel避免更新未呈现的部分。