如何在单个验证控件上实现多个验证组的效果?

时间:2018-12-31 03:28:38

标签: asp.net validation webforms validationgroup

我需要能够将多个验证组应用于页面上的某些控件,因为对于这三个提交“模式”中的每一个,都有一组不同的必填字段。

我有三个提交按钮,每个按钮都有其自己的验证组(拒绝,批准和保存)。目前,“拒绝”实际上没有任何必填字段,但将来可能会包含。 “保存”仅需要“名字”和“姓氏”,而“批准”则需要“名字”,“姓氏”和“组名”。

我尝试将多个验证组简单地放在属性值中(如下面的代码所示),但是验证根本没有触发。

我也尝试完全不指定组,以使验证始终有效,但再次重申,它根本没有触发。

<div>
    <label for='<%= txt_FirstName.ClientID %>'>First Name</label>
    <asp:TextBox ID="txt_FirstName" runat="server"></asp:TextBox>
    <asp:RequiredFieldValidator ID="rfv_FirstName" runat="server" text="Required"
        ControlToValidate="txt_FirstName" ValidationGroup="approve save">
    </asp:RequiredFieldValidator>
</div>
<div>
    <label for='<%= txt_LastName.ClientID %>'>Last Name</label>
    <asp:TextBox ID="txt_LastName" runat="server"></asp:TextBox>
    <asp:RequiredFieldValidator ID="rfv_LastName" runat="server" text="Required"
        ControlToValidate="txt_LastName" ValidationGroup="approve save">
    </asp:RequiredFieldValidator>
</div>
<div>
    <label for='<%= ddl_GroupName.ClientID %>'>Group Name</label>
    <asp:DropDownList ID="ddl_GroupName" runat="server"></asp:DropDownList>
    <asp:RequiredFieldValidator ID="rfv_GroupName" runat="server" text="Required"
        ControlToValidate="ddl_GroupName" ValidationGroup="approve">
    </asp:RequiredFieldValidator>
</div>
<div>
    <asp:Button ID="btn_Reject" runat="server" Text="Reject"
        ValidationGroup="reject" OnClick="btn_Reject_Click" />
    <asp:Button ID="btn_Approve" runat="server" Text="Approve"
        ValidationGroup="approve" OnClick="btn_Approve_Click" />
    <asp:Button ID="btn_Save" runat="server" Text="Save"
        ValidationGroup="save" OnClick="btn_Save_Click" />
</div>

我敢肯定,可以通过一些附加代码或为每个验证组使用重复的验证器控件来达到预期的效果,但是我希望webforms框架具有更简单的内置方法来实现这一目标。

更新(2018-01-02):
问题"Is it possible to assign Multiple Validation Groups to a single Validation Control?"是我自己的特例。它具有多个组中的单个控件,而我具有多个重叠组中的多个控件。另外,答案建议对每个输入/组组合具有验证控件。这是一个糟糕的解决方案,因为除其他外,它违反了DRY(请勿重复)编程原则,并使维护/增强工作更加困难。

以上内容还链接了问题"How to validate against Multiple validation groups?"。这个问题是一个完全不同的问题(验证组内的验证组),其答案提出了需要在每个需要多个验证组的页面上为每个提交按钮编写的自定义javascript。

我正在寻找一种通用案例解决方案,该解决方案我可以编写/实现一次并应用于整个Web应用程序,因此,我不认为我的问题是上述问题的重复。

更新(2018-01-03):
在研究问题时遇到的其他问题/文章之间,以及a.bajorinas和Sunil的慷慨帮助下,我已经确定不可能在验证控制之外拥有多个验证组-box,则需要自定义代码才能达到理想的效果。我已经相应地更新了问题,以帮助希望将来实现此目标的任何人。

我将测试一种解决方案,该解决方案结合了a.bajorinas和Sunil的回答中的内容,希望以后能够提供更新。

2 个答案:

答案 0 :(得分:1)

对于您想要的用例,我唯一想到的就是在按钮单击后的代码中为验证器设置ValidationGroup,请记住,这将首先执行回发,然后验证可能对你不好。

protected void btn_save_click(object sender, EventArgs e){
    rfv_FirstName.ValidationGroup = "save";
    Page.Validate("save");
    if (Page.IsValid)
    {
        //logic if validators pass
    }
}

这将使您可以将验证器重复用于多个组。 同样在我的链接文章中,对所选答案的评论之一是“无法将多个组分配给一个验证控件”

答案 1 :(得分:0)

ASP.Net不支持多个验证组。但是,使用少量JavaScript代码,您可以使其支持多个验证组。 您需要做的是覆盖IsValidationGroupMatch的标准JavaScript函数。此功能是ASP.Net中标准验证库的一部分。

在aspx页面的底部,只需添加下面给出的脚本标签。请注意,此脚本位于关闭form,body和html标签之前,这对于覆盖JavaScript函数非常重要。

<script type="text/javascript">
            window["IsValidationGroupMatch"] = function (control, validationGroup) {
                if ((typeof (validationGroup) == "undefined") || (validationGroup == null)) {
                    return true;
                }
                var controlGroup = "";
                var isGroupContained = false;
                if (typeof (control.validationGroup) == "string") {
                    controlGroup = control.validationGroup;
                    var controlGroupArray = [];
                    if (validationGroup.indexOf(",") > -1) {
                        controlGroupArray = validationGroup.split(",");// validationGroup.split(",");
                    }
                    for (var i = 0; i < controlGroupArray.length; i++) {
                        if (controlGroupArray[i].trim() == controlGroup.trim()) {
                            isGroupContained = true;
                        }
                    }
                }
                return (controlGroup == validationGroup || isGroupContained);
            }
        </script>
    </form>
</body>
</html>

完成此操作后,您可以为验证多个验证组的按钮添加一个以逗号分隔的验证组列表,如下例所示。在下面的示例中,标识为btnMultipleValidationGroups的按钮正在验证group1和group2。

<div>
            TextBox1 : 
            <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
            <asp:RequiredFieldValidator ID="RequiredFieldValidator1" runat="server" ErrorMessage="TextBox1 needs input"  ControlToValidate="TextBox1" ForeColor="Red" ValidationGroup="group1"></asp:RequiredFieldValidator>

            <br />
            <br />
            TextBox2 : 
            <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
            <asp:RequiredFieldValidator ID="RequiredFieldValidator2" runat="server" ErrorMessage="TextBox2 needs input"  ControlToValidate="TextBox2" ForeColor="Red" ValidationGroup="group2"></asp:RequiredFieldValidator>
            <br />
            <br />
            TextBox3 :
             <asp:TextBox ID="TextBox3" runat="server"></asp:TextBox>
            <asp:RequiredFieldValidator ID="RequiredFieldValidator3" runat="server" ErrorMessage="TextBox3 needs input"  ControlToValidate="TextBox3" ForeColor="Red" ValidationGroup="group3"></asp:RequiredFieldValidator>

            <br />
            <br />
        </div>
        <asp:Button ID="btnMultipleValidationGroups" runat="server" Text="Validate group1 and group2" ValidationGroup="group1,group2" OnClick="btnMultipleValidationGroups_Click" />
        <asp:Button ID="btnGroup1" runat="server" Text="Validate only group1" ValidationGroup="group1" OnClick="btnGroup1_Click" />
        <asp:Button ID="btnGroup2" runat="server" Text="Validate only group2" ValidationGroup="group2" OnClick="btnGroup2_Click" />