2

我有一个 h:selectOneMenu 设置,看起来像这样:

<f:view>
    <h:form id="tehForm">
        <h2>Header</h2><br/>
        <a4j:outputPanel id="msgPanel" ajaxRendered="true">
            <h:messages styleClass="message"/>
        </a4j:outputPanel>
        <a4j:outputPanel id="mainPanel" ajaxRendered="true"><br/>
            Select an item:<br/>
            <h:selectOneMenu id="itemMenu" value="#{bean.itemId}">
                <f:selectItem itemValue="-1" itemLabel="Please Select..."/>
                <s:selectItems value="#{bean.item}" itemValue="#{item.id}" var="item" label="#{item.name}"/>
                <a4j:support event="onchange" action="#{bean.selectItem}"/>
            </h:selectOneMenu>
            <rich:spacer width="10px"/>
            <a4j:commandLink value="Create New" action="#{bean.createNew}"
                             rendered="#{bean.selectedItemId != 0}"/>
            <h:outputText rendered="#{bean.selectedItemId gt -1}" value="Item Name:  "/><br/>
            <h:inputText rendered="#{bean.selectedItemId gt -1}" value="#{bean.selectedItem.name}" maxlength="50" size="75"/><br/><br/>
            <a4j:commandButton value="Save New" action="#{bean.save}" rendered="#{bean.selectedItemId == 0}"/>
            <a4j:commandButton value="Save Changes" action="#{bean.save}" rendered="#{bean.selectedItemId gt 0}" oncomplete="jsRerender();" />
            <a4j:jsFunction name="jsRerender" rerender="mainPanel"/>
        </a4j:outputPanel>
    </h:form>
</f:view>

创建新项目时,新项目确实显示在下拉列表中,但如果我更改项目的“名称”属性并保存,标签在下一次请求之前不会更改为新名称,尽管bean 中的数据已更改。

所以我通过在保存更改完成后强制再次调用重新渲染来解决它。问题是,这也会重新呈现消息面板,所以我会删除任何可能已显示的消息。使用limitToList="true"in 与a4j:jsFunction不调用它的效果相同。

我需要建议;要么是重新渲染功能的新目标,要么是解决问题的另一种方法。提前致谢!

4

1 回答 1

0

尝试删除oncompletejavascript 并使用reRender="mainPanel"

<a4j:commandButton value="Save Changes" 
                   action="#{bean.save}" 
                   rendered="#{bean.selectedItemId gt 0}"
                   reRender="mainPanel" />

在您的版本中,我认为没有reRender属性的“保存更改”按钮将重新呈现所有页面,从而刷新消息。

于 2011-04-01T08:46:14.533 回答