0

我在使用列表视图中的按钮从数据表中删除数据行时遇到问题。我正在尝试使用选中的按钮来删除该行。

protected void ShoppingCart_SelectedIndexChanged(object sender, EventArgs e)
{

     String title = ((Label)(ShoppingCart.Items[ShoppingCart.SelectedIndex].FindControl("Title"))).Text;
    DataTable shoppingcart = (DataTable)HttpContext.Current.Session["Cart"];
    DataRow[] rows = shoppingcart.Select("Title ='" + title + "'");

    for (int i = rows.Length - 1; i >= 0; i--)
    {
        shoppingcart.Rows.Remove(rows[i]);
    }

    shoppingcart.AcceptChanges();
    ShoppingCart.DataSource = shoppingcart;
    ShoppingCart.DataBind();
}

购物车的列表视图::

 <asp:ListView ID="ShoppingCart" runat="server" onselectedindexchanged="ShoppingCart_SelectedIndexChanged" 
        >

<ItemTemplate>
<table>
<tr>
<td>
<asp:Label ID="idlabel1" runat="server" Text='<%#Eval("id") %>' />
</td>
<td>
<asp:Label ID="titlelabel" runat="server" Text='<%# Eval("Title")%>'></asp:Label>
</td>
<td>
<asp:Label ID="pricelabel" runat="server" Text='<%#Eval("Price") %>'></asp:Label>
</td>
<td>
    <asp:TextBox ID="quantitytb" runat="server" Width="50px" Text='<%#Eval("quantity") %>'></asp:TextBox>
</td>
<td>
    <asp:Label ID="subtotallabel" runat="server" Text='<%#getsubtotal(decimal.Parse(Eval("Price").ToString()), int.Parse(Eval("quantity").ToString())) %>'></asp:Label>
</td>
<td>
    <asp:Button ID="Button1" runat="server" Text="-" Font-Names="Web Symbols" CommandName="Select"/>
</td>
</tr>
</table>
</ItemTemplate>

</asp:ListView>

班上::

public DataTable shoppingCart()
{
    CartTable = new DataTable("cart");

    CartTable.Columns.Add("ID", typeof(Int32));
    CartTable.Columns["ID"].AutoIncrement = true;
    CartTable.Columns["ID"].AutoIncrementSeed = 1;

    CartTable.Columns.Add("Title",typeof(String));
    CartTable.Columns.Add("Price");
    CartTable.Columns.Add("quantity");
    CartTable.Columns["quantity"].DataType = typeof(Int32);


    tableRow = CartTable.NewRow();
    tableRow["Title"] = title;
    tableRow["Price"] = price;
    tableRow["quantity"] = quantity;
    CartTable.Rows.Add(tableRow);
    return CartTable;
}

我尝试删除它,但它不起作用。谁能帮我?

4

1 回答 1

0

如果要从列表视图中删除该行,则只需从列表视图中删除该项目,而不是找到数据表,然后删除并再次绑定它。

if (ListView1.SelectedItems.Count > 0)
      ListView1.SelectedItems[0].Remove();

正如我从您的代码中可以理解的那样,您将 DataTable 保持在会话中并在那里阅读表单并与 for 循环匹配

为什么不从列表视图中获取一个键值,然后使用 datatable.select("xxxxx == yyyyy") 找到该行,然后删除该行。

于 2012-05-06T17:31:09.250 回答