DataGrid编辑列EditItemTemplate和编辑按钮的关系

      在文章之前,我要先感叹一句:网络上不缺少答案,缺少的是发现答案的眼睛。。。

首先,描述一下编辑列到底是如何生成的。
   请注意,在没有点击编辑之前,模板列里面的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");
   会发现我们的推论是正确的。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值