18

每次用户单击单选按钮时,我都会尝试显示验证消息。

这仅在我单击提交按钮时有效,但在我单击单选按钮时无效:

    <h:form id="form">
        <p:panel id="panel">
            <ui:repeat value="#{questionsBean}" var="question">
                <h:panelGrid columns="3" style="margin-bottom:10px" cellpadding="5">
                    <h:outputText value="#{question.questionText}" />
                    <p:selectOneRadio id="question" value="#{question.response}"
                        validator="#{question.validate}" required="true">
                        <f:selectItem itemLabel="Yes" itemValue="Yes" />
                        <f:selectItem itemLabel="No" itemValue="No" />
                        <p:ajax update="msgQuestion" event="change"/>
                    </p:selectOneRadio>
                    <p:message for="question" id="msgQuestion" />
                </h:panelGrid>
            </ui:repeat>
            <p:commandButton id="btn" value="Save" update="panel" partialSubmit="true"/>
        </p:panel>
    </h:form>
4

1 回答 1

37

change当您想监听单选按钮(或复选框)是否被单击时,HTML DOM事件是错误的事件。您应该为此使用该click事件。

单选按钮(和复选框)的值基本上不会改变。它始终具有相同的值。问题更多的是该值是否会发送到服务器端。这由通常由 DOMclick事件触发的“已检查”状态决定。

单选按钮/复选框上事件的实际行为change取决于所使用的网络浏览器。该行为在 IE 浏览器中特别不一致。它不仅取决于使用的版本,还取决于使用的渲染模式(怪癖模式与标准模式)。也许您在测试时实际上正在使用 IE。

eventPrimeFaces <p:ajax>(和标准 JSF <f:ajax>)的默认类型valueChange已经自动涵盖了这一点:

<p:ajax update="msgQuestion" event="valueChange" />

这将change在文本输入和下拉菜单中自动生成正确的事件处理程序,并click在单选按钮和复选框中自动生成事件处理程序。

但如前所述,它已经是默认 event类型。完全省略它。

<p:ajax update="msgQuestion" />
于 2012-11-05T00:36:16.107 回答