如何验证中继器中的所有复选框均已选中

时间:2018-07-04 02:51:13

标签: c# asp.net validation webforms asprepeater

我有一个表单,该表单从数据库中提取所需的协议文本,并在转发器中将每个活动协议子句显示为单独的复选框。我需要确认在提交表单之前,已选中中继器中的所有复选框。有没有办法做到这一点,或者我应该以不同于下面的方法去完成这项工作?

当前,我有一个CustomValidator,但它仅要求至少选中一个复选框。

<h1>Agreements</h1>
        <asp:Repeater ID="rptAgreements" runat="server">
            <HeaderTemplate>
                <table>
            </HeaderTemplate>
            <ItemTemplate>
                <tr>
                    <td valign="top" style="padding:10px;">
                        <asp:CustomValidator ID="CustomValidator1" runat="server" ErrorMessage="*" ClientValidationFunction = "ValidateCheckBox"></asp:CustomValidator>
                        <asp:CheckBox ID="Agreements" value='<%# Eval("AgreementID") %>' runat="server" ClientIDMode="Static" />
                    </td>
                    <td style="padding:10px;">
                        <asp:Label ID="lblAgreementText" runat="server" Text='<%# Eval("AgreementText") %>' />
                    </td>
                </tr>
            </ItemTemplate>
            <FooterTemplate>
                </table>
            </FooterTemplate>
        </asp:Repeater>

<script type = "text/javascript">
    function ValidateCheckBox(sender, args) {
        if (document.getElementById("Agreements").checked == true) {
            args.IsValid = true;
        } else {
            args.IsValid = false;
        }
    }
</script> 

后面的代码:

try
    {
        using (SqlConnection con = new SqlConnection(FormConnstring))
        {
            using (SqlCommand cmd = new SqlCommand("sp_SelectAgreements", con))
            {
                using (SqlDataAdapter agreeDS = new SqlDataAdapter(cmd))
                {
                    cmd.CommandType = CommandType.StoredProcedure;
                    DataTable dt = new DataTable();
                    agreeDS.Fill(dt);
                    rptAgreements.DataSource = dt;
                    rptAgreements.DataBind();
                }
            }
        }
    }

2 个答案:

答案 0 :(得分:1)

您正在代码中分配ClientIDMode =“ Static”,这将在HTML中生成重复的ID,并且它不是有效的html。

您可以为您的复选框分配类别,并在JS中计数协议复选框和选定的复选框,然后您可以比较数字。 例如以下:

<input type="checkbox" class="agreement" value="1"> agreement 1
<input type="checkbox" class="agreement" value="2"> agreement 2
<input type="checkbox" class="agreement" value="3"> agreement 3
<input type="checkbox" class="agreement" value="4"> agreement 4
<input type="submit" value="GO" id="btn" />

$('#btn').click(function(){
  var chkAll=$('input.agreement').length;
  var chkSelected = $('input.agreement:checked').length;
  alert(chkAll==chkSelected);
});

答案 1 :(得分:1)

您可以使用一个类并使用一个customValidator来达到目的。因此,您的代码将如下所示。

join