我在写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的事件
前台html代码
<asp:TemplateColumn HeaderText="分配角色">
<ItemTemplate>
<asp:DropDownList id="DrplRole" runat="server" Width="120px" OnSelectedIndexChanged="DrplRole_SelectedIndexChanged"
AutoPostBack="True">
<asp:ListItem Value="未分配权限">未分配权限</asp:ListItem>
<asp:ListItem Value="开单员">开单员</asp:ListItem>
<asp:ListItem Value="维护员">维护员</asp:ListItem>
</asp:DropDownList>
</ItemTemplate>
</asp:TemplateColumn>
注: AutoPostBack="True" 千万不能落下
后台c#代码
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(); // 绑定数据
}