我已经成功让代码实现了我的意图,但我不理解其中一个方面为什么有效。我正在运行Seam 2.2.2和Richfaces 3.3.3。
以下是xhtml页面的代码:
这个Backing Bean只是一个简单的POJO,具有三个属性的getter和setter。(myRadioButton、rowCountPredefined、rowCountSpecified)
这是我得到的结果:(正确的结果) 单选按钮示例 http://katzekat.de/Bilder/radio2.png 单选按钮示例 http://katzekat.de/Bilder/radio.png 这是我的想法:
将ajaxSingle设置为true意味着只有单选按钮会在服务器上处理。它旁边的下拉框不需要验证——它总是包含正确的值。我添加了process="myDropdown",以便将值持久化到Backing Bean中,否则当我将单选按钮切换到位置2时,下拉框会恢复其原始值。(我意识到这只是一种外观!)我使用调试器检查过了,它确实将属性设置在Backing Bean中,一切都按预期工作。
一旦单选按钮切换到位置2,就可以在文本框中输入值并进行验证。这个功能非常完美,当我将单选按钮切换回位置1时,如果该字段处于错误状态,则验证错误会被清除。这可能是因为请求作用域中仅存在错误消息。
当单选按钮处于位置2并在文本字段中输入有效值时,再次启动调试器后,当切换回位置1时,后台bean没有更新。我也预料到了这一点,因为我只告诉单选按钮和下拉列表在服务器上处理。然而,这是我不理解的部分——如果后备bean中没有保存此文本字段的值,那么这个文本字段的值会被保留在postback中。 (请参见上面的第二个链接)
以下是xhtml页面的代码:
...
<h:form id="radiobuttontestform">
<fieldset>
<h:panelGrid columns="3">
<h:selectOneRadio layout="pageDirection" id="myRadio" value="#{actionBean.myRadioButton}">
<f:selectItem itemLabel="First" itemValue="0" />
<f:selectItem itemLabel="Second" itemValue="1" />
<a4j:support event="onclick" ajaxSingle="true" process="myDropdown" reRender="myDropdown,myCount,test" />
</h:selectOneRadio>
<h:panelGrid columns="1" border="0">
<h:selectOneListbox size="1" id="myDropdown" value="#{actionBean.rowCountPredefined}" disabled="#{actionBean.myRadioButton != '0'}">
<f:selectItem itemLabel="10" itemValue="10" />
<f:selectItem itemLabel="20" itemValue="20" />
<f:selectItem itemLabel="30" itemValue="30" />
</h:selectOneListbox>
<h:inputText id="myCount" maxlength="5" value="#{actionBean.rowCountSpecified}" disabled="#{actionBean.myRadioButton != '1'}" required="true">
<f:validateLongRange minimum="1" maximum="1000" />
<rich:ajaxValidator event="onkeyup" for="myCount" />
</h:inputText>
<rich:message id="errorMessage" for="myCount" ajaxRendered="true" showDetail="false" showSummary="true">
<f:facet name="errorMarker">ERROR:</f:facet>
</rich:message>
</h:panelGrid>
</h:panelGrid>
</fieldset>
<h:outputLabel id="test" value="RadioValue: #{actionBean.myRadioButton}" />
<a4j:commandButton id="show" value="Show Values in Log" action="#{actionBean.showValues}" />
<a4j:commandButton id="done" value="Save and end conversation" action="#{actionBean.apply}" />
</h:form>
...
这个Backing Bean只是一个简单的POJO,具有三个属性的getter和setter。(myRadioButton、rowCountPredefined、rowCountSpecified)
这是我得到的结果:(正确的结果) 单选按钮示例 http://katzekat.de/Bilder/radio2.png 单选按钮示例 http://katzekat.de/Bilder/radio.png 这是我的想法:
将ajaxSingle设置为true意味着只有单选按钮会在服务器上处理。它旁边的下拉框不需要验证——它总是包含正确的值。我添加了process="myDropdown",以便将值持久化到Backing Bean中,否则当我将单选按钮切换到位置2时,下拉框会恢复其原始值。(我意识到这只是一种外观!)我使用调试器检查过了,它确实将属性设置在Backing Bean中,一切都按预期工作。
一旦单选按钮切换到位置2,就可以在文本框中输入值并进行验证。这个功能非常完美,当我将单选按钮切换回位置1时,如果该字段处于错误状态,则验证错误会被清除。这可能是因为请求作用域中仅存在错误消息。
当单选按钮处于位置2并在文本字段中输入有效值时,再次启动调试器后,当切换回位置1时,后台bean没有更新。我也预料到了这一点,因为我只告诉单选按钮和下拉列表在服务器上处理。然而,这是我不理解的部分——如果后备bean中没有保存此文本字段的值,那么这个文本字段的值会被保留在postback中。 (请参见上面的第二个链接)