1

嘿伙计们,我想知道如何删除已插入列表视图的项目

实际上已经在网上搜索了一段时间,找不到有用的东西。

这是我的代码,我希望能够删除我通过列表添加的内容,谢谢。

protected void Page_Load(object sender, EventArgs e)
{
  if (!IsPostBack)
  {
    List<Book> list = (List<Book>)Session["SelectedBooks"];
    if (list != null)
    {
      GridViewProducts.DataSource = list;
      GridViewProducts.DataBind();
    }
    //list of borrows
  }
}

protected void GridViewProducts_RowCommand(object sender, 
                                                     GridViewCommandEventArgs e)
{
  try
  {
    if (e.CommandName == "Remove")
    {
      GridViewProducts.DeleteRow(GridViewProducts.SelectedIndex);    
    }
  }
  catch (Exception)
  {
    lblInfo.Text = "Can not remove selected book from Bag.";           
  }
}
4

3 回答 3

2

尝试这个:

添加CommandName到 Gridview 标记内的删除按钮:

<asp:Button Text="Delete" runat="server" CommandName="Delete" />

处理RowDeleting事件,从数据源中删除项目,然后重新绑定网格视图。像这样修改你的源代码:

private List<Book> SelectedBooks
{
    get
    {
        return Session["SelectedBooks"] as List<Book>;
    }
    set
    {
        Session["SelectedBooks"] = value;
    }
}

protected void Page_Load(object sender, EventArgs e)
{
    if (!IsPostBack)
    {       
        var selectedBooks = SelectedBooks;
        if(selectedBooks == null)
        {
            // Populate the selected books first time
            // SelectedBooks = ...
        }

        BindGridview(SelectedBooks);
    }
}

private void BindGridview(List<Book> bookList)
{   
    GridViewProducts.DataSource = bookList;
    GridViewProducts.DataBind();
}

protected void GridViewProducts_RowDeleting(object sender, GridViewDeleteEventArgs e)
{      
    SelectedBooks.RemoveAt(e.RowIndex);         
    BindGridview(SelectedBooks);
}
于 2013-06-10T08:43:24.900 回答
0

使用 DataKey 属性将开源的一些主键绑定到 gridview 并在行命令中使用此数据键从数据源中删除项目,然后将网格与修改后的数据源重新绑定。

于 2013-06-10T08:14:08.880 回答
0

您必须从集合中删除项目并重新绑定(如其他答案所述)

但我看到这List<Book> list是在 Page_Load 方法中本地声明的。那么您是如何尝试实现这一目标的呢?

于 2013-06-10T08:30:13.227 回答