[英]Delete from gridview using checkbox Asp.net not working
我正在嘗試使用復選框從gridview中刪除項目,但是我有此操作並刪除了每個項目。
DataTable data = (DataTable)(GridView2.DataSource);
data.Rows.RemoveAt(GridView2.Rows.Count - 1);
data.AcceptChanges();
GridView2.DataSource = dt;
GridView2.DataBind();
然后我正在嘗試
for (int i = GridView2.SelectedRow.Count - 1; -1 < i; i--)
{
object objChecked = GridView2.SelectedRow[i].Cells[0].Value;
if ((objChecked != null) && !(bool)objChecked)
{
GridView2.Rows.RemoveAt(i);
}
}
這些是我遇到的錯誤
您有兩個主要問題:
1) GridView.SelectedRow
不是集合屬性,而是標准屬性。 因此,您不能在其上使用Count
屬性或數組索引。 要使用for
循環在行之間進行迭代,請改用GridView.Rows.Count
屬性。
for (int i = 0; i < GridView2.Rows.Count; i++)
{
// do something
}
2) GridViewRowCollection
方法中不存在RemoveAt
方法,您可以在此處看到。 您需要從數據源中刪除具有選定索引的行,然后再重新綁定到GridView
。
因此,使用foreach
循環來迭代網格行,並對每個復選框的Checked
屬性進行檢查,如下例所示。
foreach (GridViewRow row in GridView2.Rows)
{
CheckBox chk = row.FindControl("CheckBoxName") as CheckBox;
if (chk != null && chk.Checked)
{
// delete from data source (e.g. DataTable), not GridView row
dt.Rows.RemoveAt(row.RowIndex);
// you can execute delete query against DB here
}
}
// rebind the grid
GridView2.DataSource = dt;
GridView2.DataBind();
類似問題:
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.