4

preRenderView対応するイベント/リスナーで処理されるファセットページに1つのリクエストパラメーターを渡します:

<ui:define name="metadata">
    <f:metadata>
        <f:viewParam name="id" value="#{essayDetails.id}" />
        <f:event type="preRenderView" listener="#{essayDetails.init}"/>
    </f:metadata>
</ui:define>

Initメソッドが適切にアクセスされ、ページが正常にレンダリングされます。ajaxリクエストを介してモーダルパネルを表示するcommandLink(RichFacesコンポーネント)があります。

<a4j:commandLink rendered="#{essayDetails.comment}" render="create_comment_group" oncomplete="#{rich:component('create_comment_panel')}.show()">
    <h:graphicImage library="images/icons" name="comment.png" />
</a4j:commandLink>

モーダルパネルスニペット:

<ui:composition xmlns="http://www.w3.org/1999/xhtml"
            xmlns:ui="http://java.sun.com/jsf/facelets"
            xmlns:f="http://java.sun.com/jsf/core"
            xmlns:h="http://java.sun.com/jsf/html"
            xmlns:a4j="http://richfaces.org/a4j"
            xmlns:rich="http://richfaces.org/rich"
            xmlns:utils="http://java.sun.com/jsf/composite/components/utils">

<rich:popupPanel id="create_comment_panel" autosized="true">

    <f:facet name="header">
        <utils:labeledIcon label="#{msg.action_comment}" image="icons/comment.png" />
    </f:facet>

    <h:form>

        <h:panelGroup id="create_comment_group">

            <h:inputTextarea cols="80" rows="8" value="#{essayDetails.userComment}" style="resize: none;" />

            <table style="width: 100%">
                <tr>
                    <td style="width: 50%;text-align: right;">
                        <a4j:commandButton  value="#{msg.button_create}" action="#{essayDetails.saveComment}" execute="create_comment_panel_essay" render="essay_comments"  oncomplete="#{rich:component('create_comment_panel')}.hide()" />
                    </td>
                    <td style="width: 50%;text-align: left;">
                        <a4j:commandButton value="#{msg.button_cancel}" execute="@none" oncomplete="#{rich:component('create_comment_panel')}.hide()" />
                    </td>
                </tr>
            </table>

        </h:panelGroup>

    </h:form>

</rich:popupPanel>

このパネルでは、コメントがh:inputTextAreaフィールドに挿入されますが、メソッドを呼び出す代わりに対応するAcceptボタンが押されると、ポストバック要求はこのフィールドに値が必要であることを示すidパラメーター#{essayDetails.saveComment}の検証に失敗します。f:viewParam

元のコードに変更を加えずに追加した場合f:viewParam

<ui:define name="metadata">
    <f:metadata>
        <f:viewParam name="id" value="#{essayDetails.id}" required="true" />
        <f:viewParam name="v" value="#{essayDetails.v}" required="true" />
        <f:event type="preRenderView" listener="#{essayDetails.init}"/>
    </f:metadata>
</ui:define>

検証エラーはなく、動作は期待どおりです。f:viewParamやpreRenderViewイベントを使用する際に何が間違っていますか?

前もって感謝します!

4

2 に答える 2

1

これを試して:

<f:viewParam name="id" value="#{essayDetails.id}" required="#{not facesContext.postback}" />
于 2014-03-11T04:52:08.323 に答える
0

ポストバックかどうかを init() メソッドで確認してみてください。

if (!FacesContext.getCurrentInstance().isPostback()) {
    //do your initilialization
}
于 2012-11-28T14:20:01.400 に答える