用GridView进行分页时,分页大小为6,第一页有6行,第二页只有一行,
这样的话,当点击第二页回到第一页时,出现如下错误!
索引超出范围。必须为非负值并小于集合大小。 参数名: index
行 55: {
行 56: int index = Convert.ToInt32(e.CommandArgument);
行 57: GridViewRow row = gdv.Rows[index];
行 58: int userID = Convert.ToInt32(row.Cells[0].Text.ToString());
行 59: if (e.CommandName == "upgrade")
后台代码:
protected void GridView_PageIndexChanging(object sender,
GridViewPageEventArgs e)
{
gdv.PageIndex = e.NewPageIndex;
DataTable dt = BLL.Upgrade.select();
this.gdv.DataSource = dt;
this.gdv.DataBind(); //重新绑定GridView数据
}
如何才能解决,实现没有错误!
你出错的根本不是翻页代码,你贴的后台源码没有什么用。
是你的index超出范围,我的理解e.CommandArgument的值翻页后有变化,你调试跟踪一下不就ok了。
另外e.CommandArgument的值你是想用来取每行的userID吧。这段代码你要放在page_load中才行,不能放在isPostBack里面。否则index不会刷新。你看似翻页没问题,其实第一页到第二页已经不对了,不信你可以用8条记录试试,只是你正好第二页只有一条不会错,返回时才出现而已。
GridView_PageIndexChanging中的代码是没有错的,是不是你的其他的地方有错误啊!还是GridView属性设置的问题啊!可以按照一楼的提议试试啊!