在文章之前,我要先感叹一句:网络上不缺少答案,缺少的是发现答案的眼睛。。。
首先,描述一下编辑列到底是如何生成的。
请注意,在没有点击编辑之前,模板列里面的EditItemTemplate里面的控件没有生成的。当点击编辑的时候,设置this.DataGrid1.EditItemIndex = ........,然后重新绑定Grid,页面PostBack,根据你指定的第i编辑。才会生成对应的第i的编辑模板里面的控件。而这个时候,对应的这 个第i行的ItemTemplate里面的控件是不生成的。
这个我们可以做一个Test 。
<asp:DataGrid id="DataGrid1" style="Z-INDEX: 101; LEFT: 224px; POSITION: absolute; TOP: 112px" runat="server" AutoGenerateColumns="False" Width="264px">
<Columns>
<asp:BoundColumn DataField="ID" HeaderText="ID">
</asp:BoundColumn> <asp:TemplateColumn HeaderText="xx">
<ItemTemplate>
<asp:Label id=Label1 runat="server" Text='<%# DataBinder.Eval(Container, "DataItem.name") %>'> </asp:Label>
</ItemTemplate>
<EditItemTemplate>
<asp:DropDownList id="DropDownList1" runat="server"></asp:DropDownList> </EditItemTemplate> </asp:TemplateColumn>
<asp:EditCommandColumn ButtonType="LinkButton" UpdateText="更新" CancelText="取消" EditText="编辑">
</asp:EditCommandColumn>
</Columns>
</asp:DataGrid>
上面是一个DataGrid,里面有一个模板列,ItemTemplate里面有一个Label,EditItemTemplate里面有一个DropDownList,下面是后台代码。
private void Page_Load(object sender, System.EventArgs e) {
if(!Page.IsPostBack) {
DataTable dt = new DataTable();
dt.Columns.Add("ID");
dt.Columns.Add("NAME");
DataRow dr = dt.NewRow();
dr["ID"] = 1;
dr["NAME"] = "jason";
dt.Rows.Add(dr);
this.DataGrid1.DataSource = dt;
this.DataGrid1.DataBind();
}
}
private void DataGrid1_EditCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e) {
this.DataGrid1.EditItemIndex = e.Item.ItemIndex;
DataTable dt = new DataTable();
dt.Columns.Add("ID");
dt.Columns.Add("NAME");
DataRow dr = dt.NewRow();
dr["ID"] = 1;
dr["NAME"] = "jason";
dt.Rows.Add(dr);
this.DataGrid1.DataSource = dt;
this.DataGrid1.DataBind();
}
private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e) {
if(e.Item.ItemType == ListItemType.EditItem) {
DropDownList ddl = (DropDownList)e.Item.FindControl("DropDownList1");
DataTable dt = new DataTable();
dt.Columns.Add("ID");
dt.Columns.Add("NAME");
DataRow dr = dt.NewRow(); dr["ID"] = 1;
dr["NAME"] = "xxx";
dt.Rows.Add(dr);
dr = dt.NewRow();
dr["ID"] = 1;
dr["NAME"] = "jason";
dt.Rows.Add(dr);
ddl.DataSource = dt;
ddl.DataTextField = "NAME";
ddl.DataBind();
DataRowView drv = (DataRowView)e.Item.DataItem;
ddl.Items.FindByText(drv["NAME"].ToString()).Selected = true;
}
}
页面第一次加载的时候,在事件DataGrid1_ItemDataBound里面设置断点,发现,if(e.Item.ItemType == ListItemType.EditItem)里面的代码根本没有执行。这就说明:页面加载的时候,并没有生成模板列里面的 EditItemTemplate的控件。
然后点击编辑。这个时候,发现if(e.Item.ItemType == ListItemType.EditItem)里面的代码执行了。这就可以证明我们开头的结论。如果这个时候,试图去访问ItemTemplate里面的控件,我们这里是Label1,结果是显然不行的,因为这个控件已经不存在了。
在ItemDataBond的条件if(e.Item.ItemType == ListItemTypte.EditItem)里面加上代码, label lb = (Label)e.Item.FindControl("Label1");
if(lb == null)
this.Page.Response.Write("Null");
会发现我们的推论是正确的。