调用存储过程使用aspnetpager,加载时无法设定默认为第二页的方法
2009-12-17 17:13
477 查看
这两天公司做了个程序,由于数据比较多,使用分页控件aspNetPager.dll(7.0.2) 控件来分页,比较方便。
不过昨天有人提了个要求,说在修改第十页的数据后,操作完了会自动返回第一页,我再到第十页的时候翻页会比较麻烦。能不能有个方法修改完了,返回的时候还是第十页,这样就方面了很多。刚开始的时候想想很简单么。只要把页数AspNetPager1.CurrentPageIndex保存在session里面 在加载的时候如果session中有值的话就把session中的值设置给 AspNetPager1.CurrentPageIndex不就行了么,
,说干就干,改过以后,修改返回来的时候CurrentPageIndex怎么还是1,而且没办法修改,
,搞了我半天,见鬼了,去网上也没找到这方面的资料介绍,郁闷啊。没办法,自己调,试了半天发现一个问题。分页控件初次加载的时候是没有数据的,它的记录数为0.但是我现在要把它设为第十页,那它做分页的显示
(上一页 4 5 6 6 7 8 .... 下一页 )的时候就会出问题,报错(0条数据没法分10页啊,
),可偏偏这个控件它就是不报错,估计是把异常捕获掉了,然后就设死加载没数据的时候就是第一页,不让修改。
知道这个道理就简单了,我离开页面之前同时保存CurrentPageIndex 和RecordCount 不就行了,下次回来的时候只要这两个值都存在,先绑定RecordCount 告诉它我有这么多条数据,再设定CurrentPageIndex ,这样它就可以做分页了,马上修改,搞定!
,记录下来,希望以后忘了还有个找的地方。
下面是部分代码:
/// <summary>
/// 保存分页控件的当前页
/// </summary>
public void SaveAspNetPagerIndex()
{
Session["ReceiveListPageIndex"] = AspNetPager1.CurrentPageIndex;
Session["ReceiveListcount"] = AspNetPager1.RecordCount;
}
protected void ANPMember_PageChanged(object sender, EventArgs e)
{
SaveAspNetPagerIndex();
Bind();
}
///在首次加载页面的时候看一下,有没有保存的记录,有就绑定
if (Session["ReceiveListPageIndex"] != null)
{
AspNetPager1.RecordCount = int.Parse(Session["ReceiveListcount"].ToString());
AspNetPager1.CurrentPageIndex = int.Parse(Session["ReceiveListPageIndex"].ToString());
}
不过昨天有人提了个要求,说在修改第十页的数据后,操作完了会自动返回第一页,我再到第十页的时候翻页会比较麻烦。能不能有个方法修改完了,返回的时候还是第十页,这样就方面了很多。刚开始的时候想想很简单么。只要把页数AspNetPager1.CurrentPageIndex保存在session里面 在加载的时候如果session中有值的话就把session中的值设置给 AspNetPager1.CurrentPageIndex不就行了么,
,说干就干,改过以后,修改返回来的时候CurrentPageIndex怎么还是1,而且没办法修改,
,搞了我半天,见鬼了,去网上也没找到这方面的资料介绍,郁闷啊。没办法,自己调,试了半天发现一个问题。分页控件初次加载的时候是没有数据的,它的记录数为0.但是我现在要把它设为第十页,那它做分页的显示
(上一页 4 5 6 6 7 8 .... 下一页 )的时候就会出问题,报错(0条数据没法分10页啊,
),可偏偏这个控件它就是不报错,估计是把异常捕获掉了,然后就设死加载没数据的时候就是第一页,不让修改。
知道这个道理就简单了,我离开页面之前同时保存CurrentPageIndex 和RecordCount 不就行了,下次回来的时候只要这两个值都存在,先绑定RecordCount 告诉它我有这么多条数据,再设定CurrentPageIndex ,这样它就可以做分页了,马上修改,搞定!
,记录下来,希望以后忘了还有个找的地方。
下面是部分代码:
/// <summary>
/// 保存分页控件的当前页
/// </summary>
public void SaveAspNetPagerIndex()
{
Session["ReceiveListPageIndex"] = AspNetPager1.CurrentPageIndex;
Session["ReceiveListcount"] = AspNetPager1.RecordCount;
}
protected void ANPMember_PageChanged(object sender, EventArgs e)
{
SaveAspNetPagerIndex();
Bind();
}
///在首次加载页面的时候看一下,有没有保存的记录,有就绑定
if (Session["ReceiveListPageIndex"] != null)
{
AspNetPager1.RecordCount = int.Parse(Session["ReceiveListcount"].ToString());
AspNetPager1.CurrentPageIndex = int.Parse(Session["ReceiveListPageIndex"].ToString());
}
相关文章推荐
- (转载)使用DbHelperSQL调用存储过程的方法
- hibernate的update() 更新延迟或者无法更新,导致同个service调用存储过程执行方法不精确
- 关于使用 Hibernate 调用存储过程方法
- 调用存储过程并且使用返回值的基本方法
- bboss persistent框架调用存储过程的返回结果为xml串的使用方法
- SqlParameter设定的value值为0时、调用的存储过程获取到的值却为null解决方法
- 使用aspnetpager,设定默认CurrentPageIndex的方法
- java 程序加载过程---3--类中申明同时申明类的静态对象 创建类的实例 访问类的静态变量 调用类的静态方法 使用反射方法 初始化类的子类对象 直接使用java.exe 调用某个类
- 使用aspnetpager,设定默认CurrentPageIndex的方法
- 轮询程序中使用的各种方法:spring调用;http调用;存储过程调用;
- 轮询程序中使用的各种方法:spring调用;http调用;存储过程调用;
- SqlParameter设定的value值为0时、调用的存储过程获取到的值却为null解决方法
- 轮询程序中使用的各种方法:spring调用;http调用;存储过程调用;
- mysql的存储过程和触发器的使用 以及php中的调用方法
- C#中的类SqlCommand对象使用方法ExecuteNonQuery()调用SQLServer存储过程时,存储过程执行成功,数据发生改变,但是返回-1
- Oracle定时调用存储过程及取整的几个方法
- 看关于Sybase存储过程的建立和使用方法
- 动态生成SQL的存储过程,以及调用方法
- Spring如何使用JdbcTemplate调用存储过程的三种情况
- java对存储过程的调用方法