原理:其实分页功能的实现大家都清楚,无非就是把一个记录集通过运算来刷选里面对应页码的记录。

接来下我们再次添加新的代码

    1. <Grid>
    2. <DataGrid  Name="dataGrid1" AutoGenerateColumns="False">
    3. <!--省略N个代码-->
    4. </DataGrid>
    5. <StackPanel Orientation="Horizontal">
    6. <TextBlock Text="转到" Margin="5"/>
    7. <TextBox Name="tbxPageNum" Text="" />
    8. <TextBlock Text="页" />
    9. <Button Content="GO"   Click="btnGo_Click"/>
    10. <Button Name="btnUp" Content="上一页"  VerticalAlignment="Center" Click="btnUp_Click"/>
    11. <Button Name="btnNext" Content="下一页"  VerticalAlignment="Center" Click="btnNext_Click"/>
    12. <TextBlock Height="20">
    13. <TextBlock Text="【共" />
    14. <TextBlock Name="tbkTotal" Foreground="Red" />
    15. <TextBlock Text="页】" />
    16. <TextBlock Text="【当前" />
    17. <TextBlock Name="tbkCurrentsize" Foreground="Red" />
    18. <TextBlock Text="页】" />
    19. </TextBlock>
    20. </StackPanel>
    21. </Grid>

首先我们先写个分页的方法,供上面这些事件调用

后台代码

  1. //number表示每个页面显示的记录数    currentSize表示当前显示页数
  2. private void Binding(int number, int currentSize)
  3. {
  4. List<Information> infoList = new List<Information>();
  5. infoList = tbInfo.GetInformationList();      //获取数据源
  6. int count = infoList.Count;          //获取记录总数
  7. int pageSize = 0;            //pageSize表示总页数
  8. if (count % number == 0)
  9. {
  10. pageSize = count / number;
  11. }
  12. else
  13. {
  14. pageSize = count / number + 1;
  15. }
  16. tbkTotal.Text = pageSize.ToString();
  17. tbkCurrentsize.Text = currentSize.ToString();
  18. infoList = infoList.Take(number * currentSize).Skip(number * (currentSize - 1)).ToList();   //刷选第currentSize页要显示的记录集
  19. dataGrid1.ItemsSource = infoList;        //重新绑定dataGrid1
  20. }
  21. //分页方法写好了 接下来就是响应下一页,上一页,和跳转页面的事件了
  22. //先定义一个常量
  23. const int Num=12;  //表示每页显示12条记录
  24. //上一页事件
  25. private void btnUp_Click(object sender, RoutedEventArgs e)
  26. {
  27. int currentsize = int.Parse(tbkCurrentsize.Text); //获取当前页数
  28. if (currentsize > 1)
  29. {
  30. Binding(Num, currentsize - 1);   //调用分页方法
  31. }
  32. }
  33. //下一页事件
  34. private void btnNext_Click(object sender, RoutedEventArgs e)
  35. {
  36. int total = int.Parse(tbkTotal.Text); //总页数
  37. int currentsize = int.Parse(tbkCurrentsize.Text); //当前页数
  38. if (currentsize < total)
  39. {
  40. Binding(Num, currentsize + 1);   //调用分页方法
  41. }
  42. }
  43. //跳转事件
  44. private void btnGo_Click(object sender, RoutedEventArgs e)
  45. {
  46. int pageNum = int.Parse(tbxPageNum.Text);
  47. int total = int.Parse(tbkTotal.Text); //总页数
  48. if (pageNum >= 1 && pageNum <= total)
  49. {
  50. Binding(Num, pageNum);     //调用分页方法
  51. }
  52. }
  53. 原文参考  http://blog.csdn.net/sanjiawan/article/details/6785394#

WPF DataGrid的分页实现的更多相关文章

  1. WPF DataGrid实现分页显示

    主要代码如下 /// <summary> /// 读取指定页面的数据 /// </summary> /// <param name="pagePerCount& ...

  2. WPF DataGrid常用属性记录

    WPF DataGrid常用属性记录 组件常用方法: BeginEdit:使DataGrid进入编辑状态. CancelEdit:取消DataGrid的编辑状态. CollapseRowGroup:闭 ...

  3. WPF DATAGRID - COMMITTING CHANGES CELL-BY-CELL

    In my recent codeproject article on the DataGrid I described a number of techniques for handling the ...

  4. SSh结合Easyui实现Datagrid的分页显示

    近日学习Easyui,发现非常好用,界面很美观.将学习的心得在此写下,这篇博客写SSh结合Easyui实现Datagrid的分页显示,其他的例如添加.修改.删除.批量删除等功能将在后面的博客一一写来. ...

  5. WPF DataGrid某列使用多绑定后该列排序失效,列上加入 SortMemberPath 设置即可.

    WPF DataGrid某列使用多绑定后该列排序失效 2011-07-14 10:59hdongq | 浏览 1031 次  悬赏:20 在wpf的datagrid中某一列使用了多绑定,但是该列排序失 ...

  6. xceed wpf datagrid

    <!--*********************************************************************************** Extended ...

  7. 关于Jquery EasyUI中的DataGrid服务器端分页随记

    一.关于DataGrid的分页和排序参数 对于分页参数不需要用户指定,程序在AJAX请求的时候会带上分页和排序需要的参数 每页显示条数:rows 当前页:page 排序字段:sort  [multiS ...

  8. 获取wpf datagrid当前被编辑单元格的内容

    原文 获取wpf datagrid当前被编辑单元格的内容 确认修改单元个的值, 使用到datagrid的两个事件 开始编辑事件 BeginningEdit="dataGrid_Beginni ...

  9. schemaeasyui实例:SSh结合Easyui实现Datagrid的分页显示

    查了好多资料,发现还是不全,干脆自己整理吧,最少保证在我的做法正确的,以免误导读者,也是给自己做个记载吧! 克日学习Easyui,发现非常好用,界面很雅观.将学习的心得在此写下,这篇博客写SSh结合E ...

随机推荐

  1. 高效PHP开发注意事项

    2015年2月26日 17:23:26 http://www.open-open.com/lib/view/open1332904714233.html

  2. sqlserver 常用语句

    1.查询表中的RID RID=RowID=(fileID:pageID:slotID) SELECT sys.fn_PhysLocFormatter(%%physloc%%) AS rid,* FRO ...

  3. mysql生成varchar类型主键排序

    用uuid生成20位的主键 SELECT LEFT(REPLACE(UUID(), '-', ''),20) FROM DUAL 另一种方法: 因为数据库中有字母 需要排序的时候去除字母,重新取最大值 ...

  4. mybatis中的oracle和mysql分页

    这段时间一直在用mybatis+spring+springMVC的框架,总结点东西吧. mybatis的oracle分页写法: <?xml version="1.0" enc ...

  5. Light OJ 1393 Crazy Calendar (尼姆博弈)

    C - Crazy Calendar Time Limit:4000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu Su ...

  6. 个人博客转移到CSDN

    因个人博客编辑的需要,现将我的博客转移到CSDN,如果没有特别需要,以后会在CSDN上继续书写博客 关于Fresco的分析以及后续的相关分析,也会转移到CSDN 个人CSDN主页: http://bl ...

  7. MySQL常用简单小命令

    1. 登录数据库: mysql -h localhost -u root -p

  8. phpstorm 8 license key

    Learn Programming===== LICENSE BEGIN =====63758-1204201000000Ryqh0NCC73lpRm!XVcxFChJ2gTUR2lZtlLXrPLb ...

  9. mac平台scala开发环境搭建

    到scala官网,下载scala的sdk,地址:http://www.scala-lang.org/download/ adeMacBook-Pro:scala- apple$ wget http:/ ...

  10. html5 表单样式 表单验证1 2 3

    html5 表单样式 ie9以下不支持 <!DOCTYPE html> <html lang="en"> <head> <meta cha ...