gridview中删除记录时弹出提示框

gridview中删除记录时弹出提示框
 
 
在gridview中,我们都希望能在删除记录时,能弹出提示框予以提示,在asp.net1.1中,都可以很容易实现,那么在asp.net 2.0中要如何实现呢?下面举例子说明,首先在HTML页面中设计好如下代码:
< asp:GridView DataKeyNames ="CategoryID" ID ="GridView1" runat ="server" AutoGenerateColumns ="False" OnRowCommand ="GridView1_RowCommand" OnRowDataBound ="GridView1_RowDataBound" OnRowDeleted ="GridView1_RowDeleted" OnRowDeleting ="GridView1_RowDeleting" >
< Columns >
< asp:BoundField DataField ="CategoryID" HeaderText ="CategoryID" />
< asp:BoundField DataField ="CategoryName" HeaderText ="CategoryName" />
< asp:TemplateField HeaderText ="Select" >
< ItemTemplate >
< asp:LinkButton ID ="LinkButton1" CommandArgument ='<%# Eval("CategoryID") % > ' CommandName="Delete" runat="server">Delete </ asp:LinkButton >
</ ItemTemplate >
</ asp:TemplateField >
</ Columns >
</ asp:GridView >

  在上面的代码中,我们设置了一个链接linkbutton,其中指定了commandname为"Delete",commandargument为要删除的记录的ID编号,注意一旦commandname设置为delete这个名称后,gridview中的GridView_RowCommand 和 GridView_Row_Deleting 事件都会被激发接者,我们处理其rowdatabound事件中:
protected void GridView1_RowDataBound( object sender, GridViewRowEventArgs e)
{
 
if (e.Row.RowType == DataControlRowType.DataRow)
 
{
  LinkButton l
= (LinkButton)e.Row.FindControl("LinkButton1");
  l.Attributes.Add(
'onclick", "javascript:return " + "confirm("是否要删除该记录? " +
  DataBinder.Eval(e.Row.DataItem, "id") + "')");
 }

}

  在这段代码中,首先检查是否是datarow,是的话则得到每个linkbutton,再为其添加客户端代码,基本和asp.net 1.1的做法差不多。

  之后,当用户选择了确认删除后,我们有两种方法对其进行继续的后续删除处理,因为我们将删除按钮设置为Delete,方法一是在row_command事件中写入如下代码:
protected void GridView1_RowCommand( object sender, GridViewCommandEventArgs e)
{
 
if (e.CommandName == "Delete")
 
{
  
int id = Convert.ToInt32(e.CommandArgument);
  
// 删除记录的专门过程
  DeleteRecordByID(id);
 }

}

  另外一种方法是使用gridview的row_deletting事件,先在页面HTML代码中,添加<asp:GridView DataKeyNames="CategoryID" ID="GridView1" runat="server" AutoGenerateColumns="False" OnRowCommand="GridView1_RowCommand" OnRowDataBound="GridView1_RowDataBound" onRowDeleting="GridView1_RowDeleting">
然后添加row_deleting事件:
protected void GridView1_RowDeleting( object sender, GridViewDeleteEventArgs e)
{
 
int categoryID = (int) GridView1.DataKeys[e.RowIndex].Value;
 DeleteRecordByID(categoryID);
}

  要注意的是,这个必须将datakeynames设置为要删除记录的编号,这里是categoryid.

   小结

  在本文中,继续探讨了gridview控件的一些用法,如导出到excel,在删除记录时的处理,以及如何访问gridview中的控件等。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值