验证GridView

时间:2016-09-01 13:58:15

标签: c# asp.net gridview

我已尝试在StackOverflow和其他网站上查找此内容,但无法找到与我的问题相符的内容。基本上,我有一个带有下拉菜单的gridview和行中包含的文本框。用户需要从下拉列表中选择一个选项,并根据他们选择的选项,他们可能还需要将一些数据添加到同一行的文本框中。作为其中的一部分,我想运行验证以警告用户他们尚未完成哪些字段 - 但我想尝试在asp.net C#中执行此操作(如果可能)(不使用JavaScript,或JQuery,或其他任何内容)如果我可以避免它。)

我已经能够到目前为止:如果没有选择下拉列表,或者没有输入文本,则gridview将验证 - 但它会针对每一行发出错误消息,甚至如果只有一行是不正确的,而我只希望验证消息出现在那些不是的行上。

我的代码是:

<asp:UpdatePanel ID="upCurrentServicesGrid" UpdateMode="Conditional" runat="server">
    <ContentTemplate>
        <asp:GridView ID="grdviewCurrentSystems" CssClass="table-data currentSystemTable" UseAccessibleHeader="true" AutoGenerateColumns="false" runat="server">
            <Columns>
                <asp:BoundField DataField="systemName" HeaderText="Service" ItemStyle-Width="10%"/>

                <asp:TemplateField HeaderText="Status" ItemStyle-Width="39%">
                    <ItemTemplate>
                        <asp:DropDownList ID="aspdropSystemStatus" CausesValidation="false" runat="server" />
                            <div style="display:none">
                            <asp:TextBox ID="RowId" runat="server" Text='<%# Eval("id") %>' />
                            </div>
                            <div style="display:none">
                                <asp:TextBox ID="SelectedVal" runat="server" Text='<%# Eval("systemStatus") %>' />
                            </div>
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:TemplateField HeaderText="Further information" ItemStyle-Width="50%">
                    <ItemTemplate>
                        <div>
                            <asp:TextBox ID="txtSystemStatusInfo" TextMode="MultiLine" MaxLength="300" CssClass="textarea1" runat="server" Text='<%# Eval("systemInformation") %>' />
                                <asp:CustomValidator
                                    CssClass="CustomValidator1"
                                    OnServerValidate="grdviewFurtherInfo_Validate" 
                                    Display="Dynamic"
                                    runat="server"
                                    ValidationGroup="valgrpLocal">
                                        <asp:ValidationMessageLocal 
                                            CssClass="aspvalmsgLocal" 
                                            ID="aspvalSystemStatus" 
                                            Title="Service statuses" 
                                            TextPassed="" 
                                            TextFailed="Check Status or Further Information fields" 
                                            runat="server" />
                                    </asp:CustomValidator>
                        </div>
                    </ItemTemplate>
                </asp:TemplateField>
                <asp:TemplateField HeaderText="Delete" ItemStyle-HorizontalAlign="Center" ItemStyle-VerticalAlign="Middle">
                    <ItemTemplate>
                        <div>
                            <asp:LinkButton ID="lnkbtnDelSystem" CausesValidation="false" OnClick="lnkbtnDelSystem_Click" OnClientClick="return confirmDelete(this.id); return false;" CommandArgument='<%# Eval("id") %>' runat="server">
                                <span class="btn btn-small btn-spinner btn-grid">X</span> 
                            </asp:LinkButton>
                        </div>
                    </ItemTemplate>
                </asp:TemplateField>
            </Columns>
        </asp:GridView>
    </ContentTemplate>
</asp:UpdatePanel>

我的代码背后是:

protected void grdviewFurtherInfo_Validate(object sender, ServerValidateEventArgs e)
{

    bool valid = true;
    foreach (GridViewRow row in grdviewCurrentSystems.Rows)
    {
        usercontrols_asp_formctl_dropdownlist aspDrop = (usercontrols_asp_formctl_dropdownlist)row.FindControl("aspdropSystemStatus");
        usercontrols_asp_formctl_textbox aspTxt = (usercontrols_asp_formctl_textbox)row.FindControl("txtSystemStatusInfo");


        if (aspDrop.SelectedValue == "")
        {
            valid = false;
        }
        else if (aspDrop.SelectedValue != "1" && string.IsNullOrEmpty(aspTxt.Text))
        {
            valid = false;
        }
        e.IsValid = valid;
    }


}

有人可以提供建议吗?

谢谢! :)

2 个答案:

答案 0 :(得分:0)

尝试这个而不是每个循环。

    int selRowIndex = ((GridViewRow)(((DropDownList )sender).Parent.Parent)).RowIndex;
         usercontrols_asp_formctl_dropdownlist aspDrop = (usercontrols_asp_formctl_dropdownlist)grdviewCurrentSystems.Rows[selRowIndex].FindControl("aspdropSystemStatus");
            usercontrols_asp_formctl_textbox aspTxt = (usercontrols_asp_formctl_textbox)grdviewCurrentSystems.Rows[selRowIndex].FindControl("txtSystemStatusInfo");
 if (aspDrop.SelectedValue == "")
        {
            valid = false;
        }
        else if (aspDrop.SelectedValue != "1" && string.IsNullOrEmpty(aspTxt.Text))
        {
            valid = false;
        }
        e.IsValid = valid;

答案 1 :(得分:0)

您可以为GridView中的每一行使用CustomValidator

<asp:CustomValidator ID="CustomValidator1" runat="server" ErrorMessage="Input incorrect" ValidationGroup='<%# "valGroup_" + Container.DataItemIndex %>' ClientValidationFunction="myValidator" ControlToValidate="aspdropSystemStatus" Display="Dynamic"></asp:CustomValidator>

对于gridview之外的客户端脚本:

<script type="text/javascript">
    function myValidator(oSrc, args) {
        //get the rownumber that fires the validator
        var rowNumber = oSrc.id.split("_")[3];
        //get the id of the dropdown of the row
        var DropDownID = "mainContentPane_grdviewCurrentSystems_aspdropSystemStatus_" + rowNumber;
        //get the id of the textbox of the row
        var TextBoxID = "mainContentPane_grdviewCurrentSystems_txtSystemStatusInfo_" + rowNumber;
        //is the row correctly filled out
        if (document.getElementById(DropDownID).selectedIndex > 0 && document.getElementById(TextBoxID).value == "") {
            args.IsValid = false;
        } else {
            args.IsValid = true;
        }
    }
</script>

为此,您必须执行以下操作:

ValidationGroup='<%# "valGroup_" + Container.DataItemIndex %>'添加到需要在行中进行验证的每个元素和保存按钮。通过将Container.DataItemIndex(行号)添加到名称,使验证组名称唯一。如果它不是唯一的,它会将所有行验证为单个组,这不是您想要的。

检查oSrc.id.split("_")[3];是否为您提供行号。在我的情况下,ID看起来像mainContentPane_grdviewCurrentSystems_CustomValidator1_1,这就是我们在分割ID后需要第3个值的原因。

检查要验证的DropDown和TextBox的id,并在javascript中将它们设置为变量。如果ID看起来像这样mainContentPane_grdviewCurrentSystems_aspdropSystemStatus_0,只需删除行号并将其替换为javascript的rowNumber