1

我有一个页面,其中包含<input type="text">具有required="true"属性集的字段。我还有一个提交表单的保存按钮。

不幸的是,即使该required="true"字段为空,表单也会提交。

这是我当前的代码:

<s:decorate template="layout/edit.xhtml" id="decAQty">
    <ui:define name="label">Actual Qty Received</ui:define>
    <h:inputText
        value="#{tktReceivingInfoHome.instance.actualReceivedQty}"
        required="true" id="txtAQty"
        converterMessage="Not a valid Quantity">
        <a:ajax event="blur" render="txtAcTotal,decAQty"
            listener="#{returnsReceivingManager.setActualTotal}" />

    <h:messages id="error" style="display:none" />
    </h:inputText>

<a:commandButton id="btnSave"
    action="#{returnsReceivingManager.checkQtyDiff}" value="Save"
    render="decSQty,decScQty,decRtvQty,addForm,decAQty,decRecdDate,decRecWH,decErrorRMA,decErrorRTV,decReason,decStatusRMA,decStatusRTV,decPriority,decResolution"
    oncomplete="#{returnsReceivingManager.rmaInfo.qtyDiff!=0 ? '#{rich:component(\'addPanel\').show();' : 'callSave();'}"
    onclick="showProgressBar()" />
<a:jsFunction action="#{returnsReceivingManager.save}"
    oncomplete="hideProgressBar()" name="callSave" />

当我单击保存按钮时,我可以看到消息弹出,指示该值是必需的,但它随后消失并给我一条消息,指出事务失败。

换句话说,页面似乎被提交了两次。我希望社区可以提供有关如何解决此问题的任何建议。

4

1 回答 1

0

目前验证仅在离开txtAQty现场时触发(模糊事件)。这就是您看到错误消息的原因。接下来发生的是单击保存按钮,该按钮执行某些字段的重新呈现,但不对任何字段进行处理(包括验证)。这就是错误消失的原因。

您应该将process属性添加到 commandButton,其值至少列出该txtAQty字段(但更好的是您正在重新呈现的所有其他字段)

于 2012-09-21T21:00:55.050 回答