Navigation p:commandButton Primefaces Mobile



在我的应用程序中,如果在<pm:view id="mobileLogin">中登录成功,则下一个视图为<pm:view id="mobileTree">。在mobileTree视图中,我想要一个commandButton来调用一个登出方法,该方法将返回String‘pm:mobileTree?reverse=true'。问题是这不起作用。有什么想法吗?

我的代码:

 <!-- Login View -->
    <pm:view id="mobileLogin">
        <pm:header title="LiteDoc" />
        <pm:content>
            <h:form id="mobileLoginForm">
                <p:outputPanel id="container">
                    <h:panelGroup rendered="#{not loginManager.loggedIn}" >
                        <p:inputText id="username" value="#{loginManager.username}" />
                        <p:watermark for="username" value="Login" />
                        <p:password id="password" value="#{loginManager.password}" />
                        <p:watermark for="password" value="Senha" />
                        <p:separator />
                        <p:commandButton value="Login" icon="refresh" process="@form" update=":mobileTreeForm" action="#{loginManager.loginMobile}" />
                    </h:panelGroup>
                </p:outputPanel>
            </h:form>
        </pm:content>
    </pm:view>
    <!-- Tree View -->
    <pm:view id="mobileTree">
        <pm:header title="LiteDoc">
            <!-- Here's the problem --><p:commandButton value="Go" action="pm:mobileLogin?reverse=true" />
        </pm:header>
        <pm:content>
            <h:form id="mobileTreeForm">
                <p:dataList  value="#{cabinetManager.cabinets}" var="cabinet" rendered="#{loginManager.loggedIn}">
                    <p:column>
                       <h:outputText value="#{cabinet.name}" />
                    </p:column>
                </p:dataList>
            </h:form>
        </pm:content>
    </pm:view>

在服务器中执行方法并导航到其他pm:view的正确方法是这个

 <p:commandButton value="Text of the button" actionListener="#{youBean.yourLogOutMehod}" action="pm:theViewYouWantToNavigate" update="theViewYouWantToNavigate" />

你可以在移动视图中导航的另一种方式是使用标题

<pm:view id="youSourceView">
        <pm:header title="YourTitleView">
            <f:facet name="left"><p:button value="HOME" icon="home" href="#yourHomeViewID?reverse=true"/></f:facet>
            <f:facet name="left"><p:button value="BACKVIEW" icon="back" href="#yourBackViewID?reverse=true"/></f:facet>
        </pm:header>
        <pm:content>
           <!-- your content in the view -->
        </pm:content>      
</pm:view> 

您可以尝试在Bean中注销并简单重定向到/loginPage.jsf,它将刷新url并默认加载第一个pm:view

如PrimeFaces的移动手册(第12页)所述,如果您想调用服务器操作,然后导航到id为myViewIdpm:view,则必须执行以下操作:

<p:commandButton value="Logout" oncomplete="PrimeFaces.navigate('#myViewId', {reverse : 'true'})" action="#{loginBean.logout}" />

相关内容

  • 没有找到相关文章

最新更新