在asp.net c#中的gridview编辑项模板中从存储过程中查找下拉列表控件

时间:2013-06-03 15:30:54

标签: c# asp.net sql findcontrol edititemtemplate

我试图在网格视图的EditItemTemplate上找到一个DropDownList控件,在绘制之前用查询的结果填充它,但是永远找不到控件。

ddlParent == null

始终!

我可能会遗漏一些非常明显的东西,但我尝试了8种不同的方法来使这个查找控件正常工作,但不管我做什么,它都会出现空。

我已经包含了ASP和C#,sql应该不重要,因为我甚至无法接听电话!

ASP:

            <asp:TemplateField SortExpression="LocationArea2.Name" HeaderText="Parent Location Area">
                <ItemTemplate>
                    <asp:Label runat="server" Text='<%# Eval("LocationArea2.Name") %>' />
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:DropDownList ID="ddlParent" runat="server" AppendDataBoundItems="true" DataTextField="LocationArea2.Name"
                        DataValueField="ParentID" AutoPostBack="false" SelectedValue='<%# Bind("ParentID") %>'>
                    </asp:DropDownList>
                </EditItemTemplate>
            </asp:TemplateField>

C#:

protected void gvLocationArea_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (gvLocationArea.EditIndex == e.Row.RowIndex)
        {
            DropDownList ddlParent = (DropDownList)gvLocationArea.Rows[gvLocationArea.EditIndex].FindControl("ddlParent");
            if (ddlParent != null)
            {
                using (SalesSQLEntities db = new SalesSQLEntities())
                {
                    ddlParent.DataSource = db.GetRecursiveAreaList(Convert.ToInt32(((TextBox)gvLocationArea.Rows[gvLocationArea.EditIndex].FindControl("txtLocationAreaID")).Text), true);
                    ddlParent.DataBind();
                    ddlParent.Items.Add(new ListItem("* None", ""));
                }
            }
        }
    }

我知道这里缺少一些东西,无论我尝试过什么,都无法找到控件!

1 个答案:

答案 0 :(得分:1)

不使用FindControl,而是使用相关列的偏移索引并获取第一个控件:

(DropDownList)gvLocationArea.Rows[gvLocationArea.EditIndex].Cells[INDEX OF THE DDL].Controls[0]