我正在尝试实现一个richfaces 数据表。每行都有一个richfaces 日历、两个richfaces 自动完成功能和3 个输入文本。
我有另一种形式的命令按钮。当我在数据表的给定行中输入一些值时:
- 显示有效日期
- 这两个 autocpmpletes 可以很好地从 bean 中检索数据选择
- 我在输入文本中输入值
但是当我单击“计算”按钮时,只有文本输入被发送回支持 bean。
到目前为止,这是我想出的(这是我的 xhtml 文件的简化版本)
<h:body>
<rich:panel>
<h:form id="legForm">
<rich:dataTable value="#{bean.legsForDisplay}" var="legForDisplay">
<rich:column>
<f:facet name="header">
<h:outputText value="Departure Date (UTC)" />
</f:facet>
<rich:calendar value="#{legForDisplay.departureTime}"
locale="#{bean.locale}" popup="true"
datePattern="#{legForDisplay.datePattern}"
converter="dateConverter" inputStyle="width:80px">
<f:ajax event="change" execute="@this"/>
</rich:calendar>
</rich:column>
<rich:column>
<f:facet name="header">
<h:outputText value="ETD (HHmm)" />
</f:facet>
<h:inputText value="#{legForDisplay.etd}" style="width : 30px;">
<f:ajax event="change" execute="@this"/>
</h:inputText>
</rich:column>
<rich:column>
<f:facet name="header">
<h:outputText value="ADEP" />
</f:facet>
<rich:autocomplete mode="cachedAjax" minChars="2"
autocompleteMethod="#{bean.autocomplete}"
autofill="false" value="#{legForDisplay.adep}">
<f:ajax event="change" execute="@this"/>
</rich:autocomplete>
</rich:column>
<rich:column>
<f:facet name="header">
<h:outputText value="ADES" />
</f:facet>
<rich:autocomplete mode="cachedAjax" minChars="2"
autocompleteMethod="#{bean.autocomplete}"
autofill="false" value="#{legForDisplay.ades}">
<f:ajax event="change" execute="@this"/>
</rich:autocomplete>
</rich:column>
<rich:column>
<f:facet name="header">
<h:outputText value="Male Pax" />
</f:facet>
<h:inputText value="#{legForDisplay.malePax}">
<f:ajax />
</h:inputText>
</rich:column>
<rich:column>
<f:facet name="header">
<h:outputText value="Female Pax" />
</f:facet>
<h:inputText value="#{legForDisplay.femalePax}">
<f:ajax />
</h:inputText>
</rich:column>
<rich:column>
<f:facet name="header">
<h:outputText value="Child Pax" />
</f:facet>
<h:inputText value="#{legForDisplay.childPax}">
<f:ajax />
</h:inputText>
</rich:column>
</rich:dataTable>
</h:form>
</rich:panel>
<rich:panel>
<h:form>
<a4j:commandButton value="Compute Mission"
action="#{bean.doStuff}"
render="@form">
</a4j:commandButton>
</h:form>
</rich:panel>
</h:body>
如何将日历/自动完成组件中的值设置为List中的相应legForDisplay
元素?legsForDisplay
我试图阅读有关该主题的所有相关问题,但找不到该问题的解决方案,这似乎相当基本......
谢谢
编辑 :
如果在丰富的数据表中放置一个虚拟提交按钮,一切正常。我可以按下这个虚拟按钮,然后“计算任务”和值已经存储在 bean 中。
<a4j:commandButton value="Submit"
action="#{missionHandler.dummySubmit}" limitRender="true"
render="legTable">
</a4j:commandButton>
我担心的是我想从位于另一个面板中的“计算任务”按钮以另一种形式提交,而无需先单击“虚拟按钮”。