通过listview控件删除datatable中的datarow

时间:2012-05-06 17:16:45

标签: c# asp.net listview datatable datarow

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

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();
}

购物车的Listview ::

 <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>

class ::

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;
}

我尝试删除它但不起作用。任何人都可以帮助我吗?

1 个答案:

答案 0 :(得分:0)

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

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

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

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