如何使用h:commandLink和f:ajax呈现panelGroup



我想在用户点击<h:commandLink>时渲染<h:panelGroup>

我可以使它工作没有ajax,但整个页面刷新。当我尝试使用<f:ajax>时,则不调用该动作。

这是如何引起的,我该如何解决?

下面是我的链接代码:

   <a4j:outputPanel>
        <h:commandLink action="#{ObjetEleve.showInfosPersos}" style="text-decoration:none;">
            <a4j:ajax event="click" render=":corps:panelInfos"/>
            <a4j:outputPanel layout="block" styleClass="menu_item_static_header">
                <h:panelGroup layout="block" styleClass="menu_item_static">
                    <h:outputText value="#{(ObjetEleve.displayModifications) ? 'Retour au mur' : 'Modifier mes informations'}" />
                </h:panelGroup>
            </a4j:outputPanel>
        </h:commandLink>
    </a4j:outputPanel>

下面是我想要渲染的面板的代码:

 <h:panelGroup id="panelInfos">
    <h:panelGroup id="infoPerso"
        rendered="#{(ObjetEleve.displayModifications) ? true : false}"
        layout="block">
        <a4j:outputPanel id="infosPersos" layout="block">
            <h:panelGrid width="580" columns="2" border="0">
                <h:panelGrid id="panelInscription" columns="2" border="0"
                    cellspacing="0" cellpadding="0">
                    <a4j:outputPanel>
                        <h:outputText value="Nom" />
                        <h:outputText value="*" style="color:#ff0000;" />
                    </a4j:outputPanel>
                    <a4j:outputPanel>
                        <h:inputText id="nomInscription"
                            value="#{ObjetEleve.nom_eleve}" styleClass="inputbox"
                            required="true" requiredMessage="Nom obligatoire" />
                    </a4j:outputPanel>
                    <h:outputText value="" />
                    <h:outputText value="" />
                    <a4j:outputPanel>
                        <h:outputText value="Prénom" />
                        <h:outputText value="*" style="color:#ff0000;" />
                    </a4j:outputPanel>
                    <a4j:outputPanel>
                        <h:inputText id="pnomInscription"
                            value="#{ObjetEleve.prenom_eleve}" styleClass="inputbox"
                            required="true" requiredMessage="Prénom obligatoire" />
                    </a4j:outputPanel>
                    <h:outputText value="" />
                    <h:outputText value="" />
                    <a4j:outputPanel id="pwd">
                        <h:outputText value="Mot de passe" />
                        <h:outputText value="*" style="color:#ff0000" />
                    </a4j:outputPanel>
                    <a4j:outputPanel>
                        <h:inputSecret id="passwd" value="#{ObjetEleve.pwd_eleve}"
                            redisplay="true" styleClass="inputbox" required="true"
                            requiredMessage="Mot de passe obligatoire" />
                    </a4j:outputPanel>
                    <h:outputText value="" />
                    <h:outputText value="" />
                    <a4j:outputPanel id="classe">
                        <h:outputText value="Classe" />
                        <h:outputText value="*" style="color:#ff0000" />
                    </a4j:outputPanel>
                    <a4j:outputPanel>
                        <rich:select value="#{ObjetEleve.id_classe_eleve}">
                            <f:selectItems value="#{classeBean.classes}" var="classe"
                                itemValue="#{classe.id_classe}"
                                itemLabel="#{classe.nom_classe}" />
                        </rich:select>
                    </a4j:outputPanel>
                    <h:outputText value="" />
                    <h:outputText value="" />
                    <a4j:outputPanel>
                        <h:outputText value="E-Mail" />
                        <h:outputText value="*" style="color:#ff0000" />
                    </a4j:outputPanel>
                    <a4j:outputPanel>
                        <h:inputText id="email" size="30"
                            value="#{ObjetEleve.email_eleve}" styleClass="inputbox"
                            required="true" requiredMessage="Email obligatoire" />
                    </a4j:outputPanel>
                    <h:outputText value="" />
                    <h:outputText value="" />
                    <a4j:outputPanel>
                        <h:outputText value="Date de naissance" />
                        <h:outputText value="*" style="color:#ff0000" />
                    </a4j:outputPanel>
                    <a4j:outputPanel>
                        <rich:calendar value="#{ObjetEleve.date_naissance_eleve}"
                            required="true"
                            requiredMessage="Date de naissance obligatoire" />
                    </a4j:outputPanel>
                    <h:outputText value="" />
                    <h:outputText value="" />
                    <a4j:outputPanel>
                        <h:outputText value="" />
                    </a4j:outputPanel>
                    <a4j:outputPanel>
                        <h:commandButton value="Mettre à jour les informations"
                            styleClass="submitButton" />
                    </a4j:outputPanel>
                    <h:outputText value="" />
                    <h:outputText value="" />
                </h:panelGrid>
            </h:panelGrid>
        </a4j:outputPanel>
    </h:panelGroup>
</h:panelGroup>

您正在用event="click"覆盖操作组件的默认ajax事件event="action"。这样JSF就不会将动作事件排队到动作方法。

使用event="action"

<a4j:ajax event="action" render=":corps:panelInfos"/>

或者直接删除它,它已经是默认事件了

<a4j:ajax render=":corps:panelInfos"/>

同样的故事也适用于<f:ajax>

参见:

    什么值我可以传递给事件属性的f:ajax标签?

相关内容

  • 没有找到相关文章

最新更新