GridView中为按钮添加相应的事件

本文介绍如何在ASP.NET的GridView控件中为按钮添加点击事件,通过CommandArgument传递数据行ID,实现点击后显示对应ID信息的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天看一个兄弟在优快云上发了一个帖子,问在GridView中为一个按钮加一个事件,其实就是让一个panel显示出来的问题。
个人认为这个问题的主要在于GridView中为一个按钮添加事件,并把相应的ID给它,只要有ID值了。省下的事就好办多了。
下面是我做的一个小测试。功能简单,代码如下,在VS2008下测试通过.net2.0
前台:

  1. <asp:GridView ID="GridView1" runat="server" Height="174px" Width="355px" 
  2.         onrowcommand="GridView1_RowCommand" 
  3.         onrowdatabound="GridView1_RowDataBound">
  4.     <Columns>
  5.         <asp:TemplateField ShowHeader="False">
  6.             <ItemTemplate>
  7.                 <asp:Button ID="Button1" runat="server" CausesValidation="false" 
  8.                     CommandName="view" CommandArgument='<%# Eval("ID")%>' onclick="Button1_Click1" Text="点击" />
  9.             </ItemTemplate>
  10.         </asp:TemplateField>
  11.     </Columns>
  12.         
  13.     </asp:GridView>
  14.     <asp:Panel ID="Panel1" Visible="false" runat="server" Height="76px" Visible="False">
  15.         <asp:Label ID="Label2" runat="server"></asp:Label>
  16.     </asp:Panel>
后台代码:
  1.  protected void Page_Load(object sender, EventArgs e)
  2.         {
  3.             this.Label1.Text = "aaaaaaa";
  4.             if (!Page.IsPostBack)
  5.             {
  6.                 getListBox();
  7.             }
  8.         }
  9.         public void getListBox()
  10.         {
  11.             DataTable dt = new DataTable();
  12.             DataColumn dc = new DataColumn();
  13.             dc.ColumnName = "ID";
  14.             dt.Columns.Add(dc);
  15.             DataColumn dc2 = new DataColumn();
  16.             dc2.ColumnName = "Name";
  17.             dt.Columns.Add(dc2);
  18.             DataRow dr;
  19.             for (int i = 0; i <= 5; i++)
  20.             {
  21.                 dr = dt.NewRow();
  22.                 dr["ID"] = i + 1;
  23.                 dr["Name"] = "Name" + i;
  24.                 dt.Rows.Add(dr);
  25.             }
  26.             this.GridView1.DataSource = dt;
  27.             this.GridView1.DataKeyNames = new string[] {"ID"};
  28.             this.GridView1.DataBind();
  29.         }
  30.         
  31.         protected void Button1_Click1(object sender, EventArgs e)
  32.         {
  33.             string Tempstr = ((Button)sender).CommandArgument.ToString();
  34.             //Response.Write("<script>alert('"+Tempstr+"');</script>");
  35.             //这里我让Panel显示出来,并把相应的ID给label。知道了ID你就可惟做很多事了
  36.             this.Panel1.Visible = true;
  37.             this.Label2.Text = Tempstr;
  38.         }

在单击 GridView 控件中的按钮时,将引发 RowCommand 事件GridView 控件具有内置功能,用于进行编辑、删除和分页等操作。 还可以添加按钮并使用 RowCommand 事件向控件添加自定义功能。 可以通过下面的方式向 GridView 控件添加自定义功能: 向 GridView 控件添加 ButtonField 字段。 向 GridView 控件中的模板添加 Button、LinkButton 或 ImageButton 控件。 可以使用事件参数的 CommandName 属性在事件处理程序方法中标识按钮的功能。 如果使用的是 ButtonField 或 TemplateField 对象,则还可以使用 CommandArgument 属性来标识当前行。 使用的是 ButtonField 对象时,CommandArgument 属性自动设置为行索引。 使用的是 TemplateField 对象时,控件不会自动设置 CommandArgument 属性。 在这种情况下,如果必须在事件处理程序中确定行索引,则可以使用数据绑定表达式将该按钮的 CommandArgument 属性设置为行索引。 响应 GridView 控件中的按钮事件按钮的 CommandName 属性设置为标识其功能的字符串,如“打印”或“复制”。 如果使用的是 TemplateField 对象并且必须在事件处理程序方法中访问行索引,则将按钮的 CommandArgument 属性设置为标识当前行的表达式。 下面的示例演示如何将 TemplateField 列中某个按钮的 CommandArgument 属性设置为当前行索引。 在该示例中,该列包含一个显示购物车的 Button 控件。 VBC#C++F#JScript 复制不支持该语言或没有可用的代码示例。 VBC#C++F#JScript 复制 <asp:Button ID="AddButton" runat="server" CommandName="AddToCart" CommandArgument="" Text="Add to Cart" /> 为 GridView 控件的 RowCommand 事件创建一个方法。 在该方法中,执行下列操作: 检查事件参数对象的 CommandName 属性来查看传入什么字符串。 如果需要,使用 CommandArgument 属性检索包含该按钮的行的索引。 为用户单击的按钮执行相应的逻辑。 下面的示例演示响应 GridView 控件中的按钮单击的方法。 在该示例中,TemplateField 列中的按钮发送命令“AddToCart”。 RowCommand 事件处理程序确定被单击的按钮。 如果被单击的是购物车按钮,则代码执行相应的逻辑。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值