2

我有两个复选框。在提交表单之前,我需要检查是否至少检查了其中一个。

我在页面上有一个 CustomValidator。它调用一个用于服务器端验证的函数。我需要为客户端验证添加一个功能。

客户端函数应该用 JavaScript 编写。

(我不知道这是否有区别,但页面上还有其他用户控件,例如 textBoxes,它们使用其他非自定义验证器)。

这是复选框和自定义验证器控件:

<tr>
    <td colspan="3">
        <asp:CheckBox id="EmailCourse" name="EmailCourse" runat="server" />
         Email course
    </td>
</tr>
<tr>
    <td colspan="3">
        <asp:CheckBox name="SpecialReport" id="SpecialReport" runat="server" />
            Special report
    </td>
</tr>
<tr>
    <td colspan="3">
        <asp:CustomValidator id="CustomValidator1" runat="server" ErrorMessage="No checkbox checked" CssClass="error" ClientValidationFunction="validateCheckboxes_ClientValidate" OnServerValidate="validateCheckBoxes_ServerValidate"></asp:CustomValidator>
    </td>
</tr>

这是用于服务器端验证的函数:

protected void validateCheckBoxes_ServerValidate(object source, ServerValidateEventArgs args)
    {
        if (!EmailCourse.Checked && !SpecialReport.Checked)
            args.IsValid = false;
        else
            args.IsValid = true;
    }

我尝试编写客户端函数 validateCheckboxes_ClientValidate:

    <script type="text/javascript" language="javascript">

        function validateCheckboxes_ClientValidate(oSrc, args) {
            alert("inside function");
            var ec = document.getElementById("EmailCourse");
            var sr = document.getElementById("SpecialReport");
            if (!sr.checked && !ec.checked) {
                alert("hi it works");
                args.IsValid = false;
            }
            else {
                alert("one of them is checked");
                args.IsValid = true;
            }
        }
</script> 

这行不通。调用该函数,显示第一个警报,但是……就是这样!IF 语句不起作用。

怎么会?我需要做些什么来更改它,以便该函数实际验证复选框并且表单在无效时不会提交?

4

1 回答 1

0

我尝试了您的代码,它确实在使用母版页的页面中正常工作。

可能有两个可能的问题,一个如下所示,母版页已更改生成的最终标记中的 ID,如下所示,在这种情况下,您必须MainContent_EmailCourse在 JS 中用作 id

<td colspan="3">
    <span name="EmailCourse"><input id="MainContent_EmailCourse" type="checkbox" name="ctl00$MainContent$EmailCourse" /></span>
     Email course
</td>

特别报道

或者它可能是浏览器特定的问题。

于 2012-06-19T13:46:47.017 回答