我的asp.net页面中有一个ListView
表。每行都有删除按钮。单击按钮时,相应的项目将被删除。
我做了所有这些。还要在删除项目后刷新数据。
这是我的代码:
ASPX
<asp:ListView ID="CategoriesList" runat="server" ItemPlaceholderID="PlaceHolder1" OnPagePropertiesChanging="OnPagePropertiesChanging">
<LayoutTemplate>
<table>
<tr><th>Header</th></tr>
<asp:PlaceHolder runat="server" ID="PlaceHolder1"></asp:PlaceHolder>
</table>
<asp:DataPager ID="DataPager" runat="server" PagedControlID="CategoriesList" PageSize="3" QueryStringField="page">
<Fields>
//fields goes here
</Fields>
</asp:DataPager>
</LayoutTemplate>
<ItemTemplate>
<tr><td> //item goes here </td></tr>
</ItemTemplate>
</asp:ListView>
C#
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
BindListView();
}
}
private void BindListView()
{
// SQL connection string, command, etc to get the data from database
DataTable DTable = new DataTable();
SDAdapter.Fill(DTable);
CategoriesList.DataSource = DTable;
CategoriesList.DataBind();
}
protected void OnPagePropertiesChanging(object sender, PagePropertiesChangingEventArgs e)
{
(CategoriesList.FindControl("DataPager") as DataPager).SetPageProperties(e.StartRowIndex, e.MaximumRows, false);
BindListView();
}
删除某个项目后,再次调用BindListView();
即可更新数据。它运作得很好。
我的问题是当最后一页中只有一个项目被删除时,DataPager
不会转到上一页。相反,它停留在没有数据的同一页面,甚至没有表格。
如何刷新DataPager并在删除当前页面中的最后一项后转到上一页?
答案 0 :(得分:0)
use this after your page load event
protected void Page_LoadComplete(object sender, EventArgs e)
{
// BindListView();
}
这将起作用
答案 1 :(得分:0)
尝试处理已删除的事件,并从已删除的事件中绑定数据源。
<asp:ListView ID="lv1" runat="server" OnItemDeleted="lv1_ItemDeleted"></asp:ListView>
protected void lv1_ItemDeleted(object sender, ListViewDeletedEventArgs e)
{
BindListView();
}