FindControl在GridView中返回NULL
本文关键字:返回 NULL GridView FindControl | 更新日期: 2023-09-27 18:05:49
我试图操纵DropDownList
,这是在GridView
的一个字段,从ASP.NET中的代码落后。我通过使用FindControl
方法将引用添加到本地DDL来做到这一点。然而,它似乎不起作用,我尝试了多种方法(Load
, Init
事件),但我总是得到NullReferenceException
。
<asp:TemplateField HeaderText="Zuständige Führungskraft">
<ItemTemplate>
<!-- <%# Eval("ZustaendigeFuehrungskraft")%> -->
<asp:DropDownList AppendDataBoundItems="true" Enabled="false" runat="server" ID="ddwnFK" >
</asp:DropDownList>
</ItemTemplate>
<EditItemTemplate>
<asp:DropDownList AppendDataBoundItems="true" runat="server" ID="ddwnFK" >
</asp:DropDownList>
</EditItemTemplate>
</asp:TemplateField>
protected void grdBenutzer_RowEditing(object sender, GridViewEditEventArgs e)
{
SqlConnection conn = new SqlConnection(System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionString"].ToString());
conn.Open();
SqlCommand cmd = new SqlCommand("SELECT Nachname, Vorname FROM Benutzer WHERE Benutzerart='Führungskraft' AND Archiviert != 1", conn);
SqlDataReader dr = cmd.ExecuteReader();
DataTable table = new DataTable();
table.Load(dr);
foreach (GridViewRow row in grdBenutzer.Rows)
{
DropDownList ddwnFK = (DropDownList)row.FindControl("ddwnFK");
//if (ddwnFK == null)
// continue;
ddwnFK.Items.Add("keine");
foreach (DataRow dtRow in table.Rows)
{
ddwnFK.Items.Add(dtRow["Nachname"].ToString() + ", " + dtRow["Vorname"].ToString());
}
}
}
你可以试着用
DropDownList ddwnFK = (DropDownList)row.Cells[0].Controls[0];
或者在Quick watch中查看row的内容
似乎你正试图在网格的每一行找到你的下拉列表(甚至页眉/页脚行不包含你的下拉列表)。
您可以使用GridViewEditEventArgs.NewEditIndex
属性访问正在编辑的行:
var row = grdBenutzer.Rows[e.NewEditIndex];
var ddwnFK = (DropDownList)row.FindControl("ddwnFK");