很久没记录了。对象
最近在修改银光里面一个导航,使用DataGrid实现列表功能,以前使用到分页,其余人写的相似于本身写一个【上一页】【下一页】【跳转至】。。。。每一个按钮单独写了事件,后台若干全局变量控制。如今要修改此处功能,加上一些相似跳转至【1】【2】【3】【4】【5】 等等之相似页码,开始弄时有点先入为主的概念,在以前的按钮上分别去写这些事件,结果越写越乱(代码写次了),其中有实现相似于点击【下一页】或者某个页面时,动态去改变页码的功能。一堆代码写完了之后,感受头晕晕,这么写明显不该该啊。周末来加班,从新梳理下思路,决定此处应使用控件了,大概流程应该以下:事件
1.确认查询条件后,取出数据总行数。io
2.分页取出数据记录。后台
3.将数据总行数以List<int> 形式存放,将此集合实例化为对象PagedCollectionView 注: PagedCollectionView pcv = new PagedCollectionView(list);变量
4.将此对象赋值给分页控件DataPager,这样分页控件将存放全部记录数,确认每一页记录数就能够确认当前控件的总页数 注:dataPager.Source = pcv;List
5.分页控件数据源绑定完成后,添加事件PageIndexChanged,当页码发生改变时触发,这里能够获得PageIndex的值,也就是当前页码分页
6.在DataGrid中,咱们能够分页取数据,以分页控件PageIndex值为条件,进行分页查询。这样作的好处显而易见,PagedCollectionView对象没必要一次绑下大量的记录,只须要记下总记录就能够,DataGrid绑定数据时,能够分批次的去绑定。数据
7.由于有需求,因此在最后给DataPager控件添加自定义样式,让它的外观知足需求。查询