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");
   會發現我們的推論是正確的。

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章