在GridView中添加按钮后,如何触发按钮的各种事件?

//GridView中添加按钮后,如何触发按钮的各种事件?

1.在GridView的“编辑列”属性窗口中,增加新的Botton列。

2.然后再该窗口右边属性中,将外观项下的ButtonType设置一下,设置项有:如:Link、Button、Image。

3.属性设置完成后,在右边属性列表窗口的下方有这样一行超链接蓝字:将此字段转换为TemplateField,单击这个超链接,把该列插入进来的字段转换为模版。

//添加了一个删除控件,并将其转换为模版后的代码,该控件还和在GridView所在行的主键进行绑定,把主键作为参数带到该控件的各个事件函数中。

<asp:TemplateField ShowHeader="False" HeaderText="删除">

             <ItemTemplate>

                    <asp:LinkButton ID="LinkButton1" runat="server" CausesValidation="False" CommandArgument='<%# Eval("ClientID") %>'

                            OnClick="LinkButton1_Click" Text="删除"></asp:LinkButton>

                </ItemTemplate>

       </asp:TemplateField>

 

//这是一个没有绑定字段值的新增Button列,将其装换为模版后的代码如下:

<asp:TemplateField>

             <ItemTemplate>

                 <asp:Button ID="Button2" runat="server" CausesValidation="false" CommandName="" Text="按钮" OnClick="Button2_Click" />

             </ItemTemplate>

     </asp:TemplateField>

4.  然后即可在编辑模版状态下,编辑、设置这个控件的各种事件了,比如双击这个控件按钮,系统则会自动在.cs文件中添加该控件的OnClick事件触发的函数。

注意:如果你的GridView中加入了多个转换为模版的列,进入编辑模版状态后,要选择相应的转换为模版的列,才能进行编辑。如下图:


另:在cs文件中调用Gridview中按钮绑定的值:

 1 protected   void  LinkButton2_Click( object  sender, EventArgs e)
 2      {
 3        SqlConnection myconn;
 4        SqlCommand mycommand;
 5        myconn = new SqlConnection(ConfigurationManager.ConnectionStrings["BaseConnectionString"].ConnectionString);
 6        string sql = "update Bbs_Message set ISTOP=1 where Bbs_MessageIS=" + ((LinkButton)sender).CommandArgument.ToString();
 7        //Response.Write(sql);
 8        myconn.Open();
 9        mycommand = new SqlCommand(sql, myconn);
10        mycommand.ExecuteNonQuery();
11        myconn.Close();
12
13        Response.Redirect("SQS_ADD3.aspx?XkzSqsID=" + Request.QueryString["XkzSqsID"].ToString());

14    }



做网站的时候 会出现很多的不同的问题,很多书上又找不到,对于GridView的应用书上学来终觉浅呀!

网上找了很多,也试了很多方法 终于找到了简单的语句。在这里分享下,希望帮到大家。

自定义操作获取GridView行的索引:

例:在GridView模板中添加Button,单击Button的时候希望获取该操作行row,


    protected void Button1_Click(object sender, EventArgs e)
    {  

 int row = ((GridViewRow)((Button)sender).NamingContainer).RowIndex;

 

//获取该操作行中的其他控件  因为不可直接引用. 

 LinkButton lnk = (LinkButton)gv.Rows[row].FindControl("LinkButton1");

 

……//其他语句

}

 

GridView中设置隐藏列并获取隐藏列的值

网上大多是设置DataKeyNames来实现,还可以用模板来实现:

 

asp:TemplateField HeaderText=" " Visible="false"> //模板列设置成不可见。
     <ItemTemplate>
          <asp:Label ID="Label1" runat="server" Text='<%# eval_r("字段名") %>' />
                                    </ItemTemplate>
                                </asp:TemplateField>

 

Im获取还是用:

Label lbl = (Label)gv.Rows[row].FindControl("Label1");

string text=lbl.Text;//即为Lable1的值。

 

 

 

简单易明的实现效果,这篇就这样了。


  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
GridView,可以使用CommandName和CommandArgument属性为Button控件添加命令名称和参数,然后在GridView的RowCommand事件获取这些值,从而确定是哪一行的Button被点击了,进而获取该行的数据。 例如,假设GridView有一个Button控件,代码如下: ``` <asp:GridView ID="GridView1" runat="server" OnRowCommand="GridView1_RowCommand"> <Columns> <asp:ButtonField ButtonType="Button" CommandName="MyButton" CommandArgument="<%# Container.DataItemIndex %>" Text="Click" /> <!-- 其他列 --> </Columns> <!-- 数据源等设置 --> </asp:GridView> ``` 这里使用了ButtonField控件作为列,设置了CommandName为"MyButton",CommandArgument为"<%# Container.DataItemIndex %>",表示把当前行的索引传递给了按钮的参数。 接下来在GridView的RowCommand事件获取这些值: ``` protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e) { if (e.CommandName == "MyButton") { int index = Convert.ToInt32(e.CommandArgument); GridViewRow row = GridView1.Rows[index]; // 获取该行的数据,例如: string name = row.Cells[0].Text; // 假设第一列是名称列 // 其他操作 } } ``` 在RowCommand事件,首先判断命令名称是否为"MyButton",如果是,则获取CommandArgument的值,转换成整数类型,表示点击了哪一行的Button。然后可以通过GridView的Rows属性获取这一行的GridViewRow对象,进而获取该行的数据。这里假设第一列是名称列,可以通过Cells[0].Text来获取该列的文本值。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值