• λ我爱Aspx >> Asp.Net >> ASP.NET2.0中Gridview中数据操作技巧
  • ASP.NET2.0中Gridview中数据操作技巧

  • :未知  Դ:非寒日志  :2007-4-21 0:48:34  ؼ:.net,asp.net,asp.net2.0,asp,数据
  • 在上面的代码中,我们设置了一个链接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); }
    Ҷƪл˵?
  • һƪ疯狂的CN域名开始免费送拉!
    һƪASP.NET 2.0中使用multiview控件