现在的位置: 首页 > 综合 > 正文

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

2013年02月07日 ⁄ 综合 ⁄ 共 3070字 ⁄ 字号 评论关闭

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

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

 

抱歉!评论已关闭.