• 全部
  • .NET Framework
  • ASP
  • Web Services
  • .NET互联网桌面应用
  • VB
  • 图表区
  • 分析与设计
  • 组件/控件开发
  • AppLauncher
  • 问答

为什么我的datagrid.pagecount总是0,我快疯了,整整弄了三天分页(我以发过,可是还是没解决!!)

lyy5038814 2007-04-25 10:24:25
//计算页数
public int pcount(DataGrid MyDataGrid)
{
return MyDataGrid.PageCount;
}
//响应分页事件
public void pagechange(string pagemark,DataGrid MyDataGrid)
{
int pcount=this.pcount(MyDataGrid);
switch(pagemark)
{
case "first":
MyDataGrid.CurrentPageIndex=0;
break;
case "next":
if(MyDataGrid.CurrentPageIndex<pcount-1)MyDataGrid.CurrentPageIndex+=1;break;
case "pre":
if(MyDataGrid.CurrentPageIndex>0)
MyDataGrid.CurrentPageIndex-=1;
break;
case "last":
MyDataGrid.CurrentPageIndex = pcount - 1;
break;
}
}
//是不是点击超连接<a href="">(runat不是server)不触发IsPostBack事件????????
if(!this.Page.IsPostBack)
{
this.toptitle.Text="<div align=center><b>查询结果如下:</b></div>";
this.filldate(gj,lx);//将datareader中的内容放入会话表格中,既this.Session["searchtable"]);
this.DataGrid2.VirtualItemCount=((DataTable)this.Session["searchtable"]).Rows.Count;
//用于检测是first,next,pre,last,以便触发上一页,下一页,最后页,首页
if(this.Request.QueryString["type"]!=null)
{
string type=this.Request.QueryString["type"].ToString();
this.pagechange(type,this.DataGrid2);
this.Response.Write(this.DataGrid2.CurrentPageIndex);//测试用,但每次都是0
startIndex = this.DataGrid2.CurrentPageIndex * this.DataGrid2.PageSize;
this.Response.Write(this.DataGrid2.PageCount);//测试用,但每次都是0
this.BindGrid();
}
else
{
this.BindGrid();
}
}
//OnPageIndexChanged="mydatechange"(html中触发DataGrid2分页),该段代码实现了
protected void mydatechange(object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
{
this.DataGrid2.CurrentPageIndex = e.NewPageIndex;
startIndex = this.DataGrid2.CurrentPageIndex * this.DataGrid2.PageSize;
BindGrid();
}
private void BindGrid()
{
this.DataGrid2.DataSource = CreateDataSource();
this.DataGrid2.DataBind();
}
//其中DataGrid2自带的页码实现了,但就是上页下页,首页,末页总也出现currentpageindex=0,pagecount=0我也不知道是为什么?????????
...全文
281 点赞 收藏 10
写回复
10 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
anncesky 2007-04-26
如果美工也自己做的话grid挺好,如果不是,还是用list吧
回复
lyy5038814 2007-04-26
jedliu(21世纪什么最贵? 人才!) ,没有错误!
//创建数据源
private ICollection CreateDataSource()
{
DataRow dr;
DataTable dtnew=new DataTable();
DataTable dt=(DataTable)this.Session["searchtable"];
dtnew=dt.Copy();
if(this.Page.IsPostBack)
{
for(int i=0;i<dtnew.Rows.Count;i++)
{
dtnew.Rows.Remove(dtnew.Rows[i]);
dtnew.Rows.Clear();
dtnew.Dispose();
}
}
for (int i = startIndex; i < (startIndex+this.DataGrid2.PageSize); i++)
{
if(i>((DataTable)this.Session["searchtable"]).Rows.Count-1)
break;
dr = dtnew.NewRow();
dr[0] = Int32.Parse(dt.Rows[i][0].ToString());
dr[1] = dt.Rows[i][1].ToString();
dr[2] = Convert.ToDateTime(dt.Rows[i][2].ToString());
dr[3] = Int32.Parse(dt.Rows[i][3].ToString());
dtnew.Rows.Add(dr);
}
DataView dv = new DataView(dtnew);
return dv;
}
另外想问kunbrother(轻轻微笑)一下如何获的ViewState中的信息,可能是ViewState原因!!!!!!
回复
xiaoweioo 2007-04-26
asp.net控件每次点击都刷新页面,所以在page_load中不能加入!Page.ispo.....这样应该就没问题了。
如果还有问题。就在设定具体哪一页的那句代码之前,让DataGrid重新绑定一次就可以了。
回复
lyy5038814 2007-04-26
谢谢kunbrother(轻轻微笑),就是因为<a href="">不但不触发,而且等于是重新访问这个页面,其中的ViewState信息全部丢失。我用了<asp:linkbutton >就没问题了,谢谢大家的帮助!!!!!!!!!
回复
belldandy11 2007-04-26
分页的超连接<a href=""> 放到<from runat=server></from>里面 要不不会触发
回复
jedliu 2007-04-25
private void BindGrid()
{
this.DataGrid2.DataSource = CreateDataSource();
this.DataGrid2.DataBind();
}
你的这段有没有错误?
this.Response.Write(this.DataGrid2.PageCount);//测试用,但每次都是0
这显然是没赋值的结果!
回复
jedliu 2007-04-25
是不是点击超连接<a href="">(runat不是server)不触发IsPostBack事件????????
------------------------------------------------------------------------
这是客户端的,它不会发到服务端,所以肯定不触发!
回复
kunbrother 2007-04-25
“//是不是点击超连接<a href="">(runat不是server)不触发IsPostBack事件????????”


不但不触发,而且等于是重新访问这个页面,其中的ViewState信息全部丢失。
你的代码我没看明白。
回复
Iceguy 2007-04-25
难道你这些都写在Page_Load下的吗?
你把整个过程跟踪一下 每个地方都插入pagecount看看其数值变化 3天肯定能找出原因了把
回复
lyy5038814 2007-04-25
希望高手多多指点,以前我发过,但是都试过,不能解决,若能解决,立即给分
回复
相关推荐
发帖
.NET技术社区
创建于2007-09-28

5.8w+

社区成员

.NET技术交流专区
申请成为版主
帖子事件
创建了帖子
2007-04-25 10:24
社区公告
暂无公告