仰天一笑(Ansonxuyu),专业从事软件定制开发、Web软件开发,网站建设,网络推广,APP开发,微博应用开发,微信应用开发,电子商务开发,物联网开发等技术。
互联网8年风雨,愿在此交朋识友,交流心得,分享技术知识(策划/研发/运营/推广/合作)!QQ:943530498


仰天一笑

昨日不悔,今日勿失,明日莫忧! —徐羽

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  340 随笔 :: 27 文章 :: 1088 评论 :: 237万 阅读

我在写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 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" 千万不能落下


后台:

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(); // 绑定数据    
  }



posted on   仰天一笑  阅读(14364)  评论(4编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
点击右上角即可分享
微信分享提示