1

私のアプリでは<pm:view id="mobileLogin">、次のビューでログインが成功した場合はです<pm:view id="mobileTree">。mobileTreeビューで、コマンドボタンが文字列'を返すログアウトメソッドを呼び出すようにします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>
4

2 に答える 2

3

サーバーでメソッドを実行して他のメソッドに移動する正しい方法は次のとおり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が更新され、デフォルトで最初のURLが読み込まれます。pm:view

于 2013-02-25T02:39:55.860 に答える
0

PrimeFacesのモバイルマニュアル(12ページ)で説明されているように、サーバーアクションを呼び出し、その後、pm:viewIDを使用してに移動するmyViewId場合は、次の手順を実行する必要があります。

<p:commandButton value="Logout" oncomplete="PrimeFaces.navigate('#myViewId', {reverse : 'true'})" action="#{loginBean.logout}" />
于 2013-02-25T20:04:42.770 に答える