1

我想从 backing bean 更改选项卡,我该怎么做?

<h:form id=form>  

    <p:growl id="growl" showDetail="true" />  

    <p:tabView id="tabView" dynamic="true" widgetVar="detailsTab">  

        <p:ajax event="tabChange" listener="#{bean.onTabChange}" update=":form:growl"/>  

        <p:tab title="Tab1" id="emp">  
            <h:panelGrid columns="2" cellpadding="10">  


              </h:panelGrid>  
        </p:tab>  

        <p:tab title="Tab 2 " id="schedule1">  
            <h:panelGrid columns="2" cellpadding="10">  


            </h:panelGrid>  



        </p:tab>  

        <p:tab title="Tab 3" id="schedule2">  
        <p:schedule value="#{bean.eventModel}" slotMinutes="15" 
                            resizable="false" widgetVar="schdule" initialDate="#{bean.dates}" draggable="true" styleClass="#{bean.selDates}"
                             >
                             <p:ajax event="dateSelect" listener="#{bean.onDateSelect}"
                                update="dialogBox"  oncomplete="patScheduleDialog.show()"/>
                              <p:ajax event="eventSelect" listener="#{bean.onEventSelect}" 
                                update="dialogBox :form:growl" oncomplete="#{bean.pevent}"/>
                                <p:ajax event="eventMove" listener="#{bean.onEventMove}"
                                update="dialogBox, :form:growl" />
                        </p:schedule>

         <p:dialog id="dialogBox" header="Patient's Appointment Details" widgetVar="patScheduleDialog" resizable="true"  
                                 showEffect="explode" hideEffect="explode">  

                <h:panelGrid id="eventDetails" columns="2">  
            <h:outputLabel for="title" value="Title:" />  
            <p:inputText id="title" value="#{bean.event.title}" required="true"/>  

            <h:outputLabel for="from" value="From:" />  
            <p:inputMask id="from" value="#{bean.event.startDate}" mask="99/99/9999">  
                <f:convertDateTime pattern="dd/MM/yyyy" />  
            </p:inputMask>  

            <h:outputLabel for="to" value="To:" />  
            <p:inputMask id="to" value="#{bean.event.endDate}" mask="99/99/9999">  
                <f:convertDateTime pattern="dd/MM/yyyy" />  
            </p:inputMask>  

            <h:outputLabel for="allDay" value="All Day:" />  
            <h:selectBooleanCheckbox id="allDay" value="#{bean.event.allDay}" />  

            <p:commandButton type="reset" value="Reset" />  
            <p:commandButton value="Save" actionListener="#{bean.addEvent}" oncomplete="schdule.update();dialogBox.hide();"/>  
        </h:panelGrid>  


    </p:dialog>


        </p:tab>  

    </p:tabView>  


  public void onEventSelect(ScheduleEntrySelectEvent selectEvent){

    // what should I need to do here to set "Tab 2" if click on any event.


    }
4

2 回答 2

10

首先,您需要设置 的activeIndex属性<p:tabView>,如下所示:<p:tabView activeIndex="#{bean.selectedTab}">。这是一个Integer.

其次,在你的bean方法中,每当你想改变活动选项卡时,设置selectedTab为你想要选择的选项卡。

第三,记得更新<p:tabView>.


你也可以使用 JavaScript 来做到这一点。只需设置widgetVar您的属性 <p:tabView>,如下所示:<p:tabView widgetVar="myTabView">.

然后使用 JavaScript 函数myTabView.select(tabIndex)tabIndex您要选择的选项卡的索引在哪里。

您可以在任何 javascript 事件中执行此操作,例如:<p:commandButton oncomplete="myTabView.select(1)" />在 commandButton 的操作完成后选择第二个选项卡。


确保您阅读PrimeFaces 文档

于 2012-09-13T14:35:22.643 回答
0
  1. 您可以在标签 p:tabView 中使用绑定属性。
<p:tabView id="tabGeneral" binding="#{Bean.tabView}" dynamic="true">
  1. 在您的 Bean 中创建 Tabview 对象。

私有 TabView 选项卡视图;

public TabView getTabView() {
  return tabView;
}

public void setTabView(TabView tabView) {
  this.tabView = tabView;
}
  1. 将 int 设置为 tabview 中的索引。
tabView.setActiveIndex(0);
  1. 更新标签视图。
RequestContext.getCurrentInstance().update("tabGeneral");
于 2020-02-26T13:23:30.207 回答