完美解决水晶报表的翻页问题

  1. 云栖社区>
  2. 博客>
  3. 正文

完美解决水晶报表的翻页问题

龙轩8023 2012-01-13 23:38:52 浏览767
展开阅读全文

      在维护YH过程中遇到了这样一个错误:报表查询到的数据有4页,默认显示第一页,点击下一页,显示正常,再点击下一页,本来应该显示第三页的,结果还是显示第二页,点击末页和首页可以正常显示,输入页码,点击跳转按钮也可以正常显示。很奇怪的问题,但是不得不解决,客户那边有要求嘛。功夫不负有心人,历经“千辛万苦”终于解决了。

       对于伸手党来说,解决方案当然是最想先看到的,那就先说说我的解决方案吧:

【解决方案】

源代码: 

       protected void Page_Load(object sender, EventArgs e)
        {
            if (Session["Admin"] == null)
            {
                Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", "<script language='javascript' defer>alert('您的会话时间已过期,请重新登陆!');</script>");
                Response.Write("<script language=javascript>window.top.location.href='../Login.aspx'</script>");
                return;
            }
	   //查询报表并显示(按时间段查询)
	   CheckBetweenTime();
        }

修改后的代码:

        protected void Page_Load(object sender, EventArgs e)
        {
            if (Session["Admin"] == null)
            {
                Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", "<script language='javascript' defer>alert('您的会话时间已过期,请重新登陆!');</script>");
                Response.Write("<script language=javascript>window.top.location.href='../Login.aspx'</script>");
                return;
            }
            //查询报表并显示(按时间段查询)
              //CheckBetweenTime();
        }

添加代码:

        protected void CrystalReportViewer1_Navigate(object sender, EventArgs e)
        {
            //查询报表并显示(按时间段查询)
               CheckBetweenTime();          
        }

 

源码中修改:

     <CR:CrystalReportViewer ID="CrystalReportViewer1" runat="server" AutoDataBind="true" DisplayGroupTree="false"  OnNavigate="CrystalReportViewer1_Navigate"/>


再测试,OK了。

 

【解 析】MSDN上查得点击翻页会触发Navigate 事件。CrystalReportViewer 的事件成员: http://msdn.microsoft.com/zh-cn/library/ms227097(v=VS.90).aspx

所以我们只要在CrystalReportViewer 的 Navigate 事件中重新绑定数据源,这样可以从根本上解决问题。

 

网上有说将Page_Load里的数据源绑定操作,写到Page_Init事件中,这也是一种解决方案,但是这个解决方案有局限性:因为我的数据绑定是要通过界面控件数据获取的,而Page_Init事件是页面初始化的事件,这时的控件都没有赋值,所以条件当然就错了,条件错了结果也就错了。而Navigate 事件则是在Page_Init和Page_Load事件结束后,才进行的,条件可以正常获得,然后再进行绑定数据源即可。

注意:CrystalReportViewer 所有的翻页操作都会触发Navigate 事件。我们可以调用CrystalReportViewer 的单独翻页方法:

     CrystalReportViewer1.ShowFirstPage();     //首页
     CrystalReportViewer1.ShowLastPage();      //末页
     CrystalReportViewer1.ShowNextPage();      //下一页
     CrystalReportViewer1.ShowPreviousPage();  //上一页
     CrystalReportViewer1.ShowNthPage(N);      //跳转到第 N 页


有了这些方法,只要对这些方法进行重写再结合着Navigate 事件即可实现想要的功能了。

 

网友评论

登录后评论
0/500
评论
龙轩8023
+ 关注