大家在使用Grid时,总是报怨Grid的分页功能太弱,不能满足自己的需要,这在MS的DataGrid与NetAdvantage的2004vol3之前的版本都这样,Grid总是要求我们按它的要求进行显示与操作,从NetAdvantage 2004 vol 3开始,UltraWebGrid在分页显示上做了不少加强,我就简单介绍一下,我是如何使用的。
我想实现的效果图:
其实也是很简单,就是想在左面的地方,显示一些自定义的信息。
开始吧:
1)拖个UltraWebGrid到界面上,然后后台进行数据绑定我就不说了,大家有自己的方式。
2)套用一种格式
右击UltraWebGrid,选择Quick Design,然后在弹出窗口中挑选自己喜欢的模板(这跟MS的DataGrid差不多了): 记住要点击:Apply Preset才能生效的。
3)定义分页属性
UltraWebGrid的分页方式很多,我们展开DisplayLayout->Pager属性,如图:
设置AllowPaging=True; //这样就可以看到分页了
我们采用QuickPages的StyleMode,设置QuickPages=4,这是说明,界面上显示为“当前面的前后四个分页数”。
然后设置我们的Pattern,这个模板就是用来自定义显示效果的,在这个Partern中,提供了一些欲定义的域:
我想,大家一看英文就知道什么意思了吧。
为了实现效果图中的样式,我定义为:
[default]最好一定要啊。它是随着不同的分页模式显示不同的方式。
[page:1:第一页]:象这样的话,分页数的1分变成“第一页”的字样,我还没有发现此功能怎么使用比较好。
在这里最让我失望的就是没有RecordCount记录数,我想要实现这个,得用后台的代码自动添加了。
好了,方法就是这么简单,你想定义成什么样,就定义成什么样吧。
4)分页代码实现:
分页的代码是非常简单的,给UltraWebGrid添加PageIndexChange事件:
{
this.UltraWebGrid2.DisplayLayout.Pager.CurrentPageIndex=e.NewPageIndex;
this.UltraWebGrid2.DataBind();
}
好了,一切都好了。当然,你完全可做的更漂亮一些。
我是非常不推荐使用什么第三方的分页控件的,那些控件与Grid的整合都不怎么好,除非你已经用习惯了。
而且第三方的分页控件都是强调一个“高性能”分页的概念,关于这个的必要性,我也讨论过了,必要性很小。请参考:请讨论一下高性能分页的必要性!
而Grid自带的分页,可以非常轻松实现,集成也是最好的。
Feedback
如何解决?谢谢
其次还是必须研究分页的高性能实现,因为分页在不少时候是必须的,系统不可能设计得那么完美,而且实际运行中会有设计师预料不到的情况
其次还是必须研究分页的高性能实现,因为分页在不少时候是必须的,系统不可能设计得那么完美,而且实际运行中会有设计师预料不到的情况
1、显示出信息——记录数?
2、显示分页按钮:首页、前页、后页、末页
3、显示一个textbox和一按钮,用户在textbox中录入页数后单击按钮即跳转到相应页面。
敬请听棠.net指教,谢谢!
# re: 轻松实现UltraWebGrid中的分页控制 回复 更多评论
2005-06-02 20:04 by rui.star@126.com我不敢苟同.分页控件做的,恰恰是把分页逻辑与显示逻辑分开,这样的系统提高了内聚性,比如对DATAGRID的分页和DATALIST的分页,通过分页控件可以提供完全一致的分页形态.其次,与分页控件配合使用的高效分页方法,也是必须的。否则,你有两种途径:要么把数据集放到VIEWSTATE里,这样数据库是轻松了,可是页面变的非常庞大,刷新之间很慢。要么每次都取所有数据过来,这样数据库会累死。没见过C/S结构的程序分页的,原因就是不考虑INTERNET速度问题,B/S是必须高效分页的。
# re: 轻松实现UltraWebGrid中的分页控制 回复 更多评论
2005-10-26 21:06 by chenhaoying我用
this.UltraWebGrid2.DisplayLayout.Pager.CurrentPageIndex=0;没看到数据,用
this.UltraWebGrid2.DisplayLayout.Pager.CurrentPageIndex=1;才看到数据。
我的UltraWebGrid2属性设置是在Page_onload中写的,如下
oleDbConnection1.ConnectionString="Provider=Microsoft.Jet.OleDb.4.0;Data Source=" + Server.MapPath("djks0304.mdb");
oleDbConnection1.Open();
oleDbCommand1.CommandText="Select * from students";
oleDbCommand1.Connection= oleDbConnection1;
R1=oleDbCommand1.ExecuteReader();
UltraWebGrid1.DataSource=R1;
UltraWebGrid1.DataMember="student";
UltraWebGrid1.DisplayLayout.Pager.AllowPaging=true;
UltraWebGrid1.DisplayLayout.Pager.QuickPages=4;
UltraWebGrid1.DisplayLayout.Pager.PageSize=10;
//UltraWebGrid1.DisplayLayout.Pager.StyleMode=""
UltraWebGrid1.DisplayLayout.Pager.Pattern="<table width=100%><tr><td align=left>页码:[currentpageindex]/[pagecount] 每页:[pagesize]</td><td align=right>[default]<td></tr></table>";
UltraWebGrid1.DataBind();
{
this.UltraWebGrid2.DisplayLayout.Pager.CurrentPageIndex=e.NewPageIndex;
this.UltraWebGrid2.DataBind();
}
为什么不能进行分页啊??
this.UltraWebGrid2.DataBind(); 这句之前还需要绑定一下DATATABLE
控件安装好了,在工具拦里回用的,如果没有的话,还需要重新运行Create NetAdvantage Visual Studio Toolbox Tab(你安装控件的程序里有的)
导出EXCEL ,请看http://zjy.cnblogs.com/archive/2006/05/18/402991.html(Table导出为xls,doc,txt,htm方法 )