Asp.Net C# 单击按钮时从数据表网格视图中删除行

本文关键字:网格 数据表 视图 删除行 Net 单击 按钮 Asp | 更新日期: 2023-09-27 18:34:54

我正在显示一个数据表,该表从数据库中选择了许多元素(IncomingsId,类型,成本,频率(,并且不确定单击按钮时如何删除行。到目前为止,我已经尝试了许多解决方案,但没有任何效果。

这是我在网格视图中的按钮

<asp:TemplateField HeaderText="Delete">  
         <ItemTemplate>  
            <asp:button id="DeleteRowButton" text="Delete Record" onclick="DeleteRowButton_Click" runat="server"/>
         </ItemTemplate>  
     </asp:TemplateField> 

这是我创建数据表时此页面背后的代码。

 SqlConnection con;
    public _Default()
    {
        con = new SqlConnection(@"MySQLConnection");
    }
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            DisplayRecord();
        }
    }
    public DataTable DisplayRecord()
    { 
        string userId = (HttpContext.Current.User.Identity.GetUserId());
            SqlDataAdapter Adp = new SqlDataAdapter("select * from Incomings where AspNetUsersId = '" + userId +"'", con);
        DataTable Dt = new DataTable();
        Dt.AcceptChanges();
        Adp.Fill(Dt);
            grid1.DataSource = Dt;
            grid1.DataBind();
     return Dt;
    }
    public void DeleteRowButton_Click(object sender, EventArgs e)
    {
    }

提前为任何帮助干杯。我确定这是一个简单的解决方案

Asp.Net C# 单击按钮时从数据表网格视图中删除行

您需要一种方法来让代码知道要删除哪个 ID。这是我通常的做法:

将按钮替换为ItemTemplate,并在此处添加按钮:

    <Columns>
        <asp:TemplateField>
            <ItemTemplate>
                <asp:Button Text="Delete" runat="server" CommandArgument='<%# Eval("userId") %>' CommandName="Delete" />
            </ItemTemplate>
        </asp:TemplateField>
    </Columns>

以这种方式使用按钮后,您现在可以访问CommandArgumentCommandName属性。请注意,我传递的参数是 Eval("userId") ,命令名称(稍后您将看到(用于识别您要执行的操作(这可以是任何东西,只是一个名称(。

使用来自数据库/数据源的名称(我猜它会是 userId(,将CommandArgument替换为要传递给服务器的任何值。

然后,若要捕获此内容,需要实现 GridView 的 RowCommand 事件,并截获正确的CommandName

public void GridView1_RowCommand(Object sender, GridViewCommandEventArgs e)
{
    if (e.CommandName == "Delete")
    {
        string userId = e.CommandArgument.ToString();
        //do something with the id
    }
}

在这里,您必须确保按钮中的CommandName与要在RowCommand中执行的任何操作相匹配。这应该可以解决问题。

不要忘记将事件绑定到 GridView:

<asp:GridView OnRowCommand="GridView1_RowCommand" ID="GridView1" runat="server">
   ...
</asp:GridView>

只需将其用于前端代码

    <asp:GridView ID="grid1" OnRowDeleting="OnRowDeleting" DataKeyNames="deleteR" runat="server" AutoGenerateColumns="False"  CellPadding="4"  GridLines="None" style="width:100%"  >  
 <columns>  
    <asp:TemplateField HeaderText="Delete Row">
        <ItemTemplate>
            <asp:Button ID="btnDelete" runat="server" class="btn btn-primary" Text="Delete"  CommandName="Delete" OnRowDataBound="OnRowDataBound" />
        </ItemTemplate>
    </asp:TemplateField>

并在它后面有这个:

 protected void OnRowDeleting(object sender, GridViewDeleteEventArgs e)
    {
        int deleteR= Convert.ToInt32(grid1.DataKeys[e.RowIndex].Values[0]);
       //have a sql statement here that add's the parameter ID for the row you want to delete, something like
SqlCommand com  = new SqlCommand ("Delete FROM yourdatabase Where yourID = @yourID"
com.Parameters.AddWithValue("@yourID", yourID)
    }

您正在寻找的确实是一个简单的解决方案。
您可以使用 foreach 循环在DataTable中的所有 DataRow 中搜索某种 ID。
下面是我的意思的示例:

String s = "/* IncomingsId for what you want to delete */";
foreach (DataRow r in dt.Rows) {
    if (r["IncomingsId"].ToString().Equals(s)) {
        dt.Rows.Remove(r);
    }
}

只是对任何帮助过我的人的快速更新,感谢您的建议。Asp.Net 在AutoGenerateDeleteButton中内置了它自己的功能,我将其设置为true并在其背后运行了一些代码。一个简单的解决方案,真的不应该花我一整天的时间来完成!