我在写DataGrid控件中子控件事件时候,DropDownList的事件相比而言麻烦一点,在此,我简单罗列如下(我在此处为了方便这里都用DataGrid中的隐藏列存储我所要的数据):

一、DropDownList的动态绑定,只需在DataGrid1_ItemDataBound的事件中,取出数值进行匹配,便可以了,具体代码如下:
private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
  {
   if ((e.Item.ItemType == ListItemType.Item)||(e.Item.ItemType == ListItemType.AlternatingItem)) 
   {
    string StrPower = e.Item.Cells[3].Text; // 用隐藏列取出数据
    DropDownList DrpRole = (DropDownList)e.Item.Cells[4].FindControl("DrplRole");
    for(int i=0;i<DrpRole.Items.Count;i++)
    {
     if(StrPower.Equals(DrpRole.Items[i].Value))
     {
      DrpRole.Items[i].Selected = true;

     }
    }    
   }
  }

二、触发DataGrid中DropDownList的事件

前台:

<asp:TemplateColumn HeaderText="分配角色">
        <ItemTemplate>
         <asp:DropDownList 千万不能落下


后台:

public void DrplRole_SelectedIndexChanged(object sender, System.EventArgs e)
  {
   // 选择用户类型   semir.customClass.database dbnew = new semir.customClass.database();
   DropDownList DrplRole = (DropDownList)sender;
   TableCell cell = (TableCell)DrplRole.Parent;
   DataGridItem item = (DataGridItem)cell.Parent;

   string StrPower = ((DropDownList)sender).SelectedItem.ToString(); // 取出DropDownList选中项文本
   int ITid = Convert.ToInt32(item.Cells[0].Text);    // 取出该行的第一格的数据(主键)
   string sqlUpPower = "update ITUsers set ITPower='"+StrPower+"' where ITID='"+ITid+"'";
   dbnew.DatabaseCommand(sqlUpPower); // 数据库操作

   BindDataUser(); // 绑定数据    
  }



相关文章: