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

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

    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. Java动态加载类在功能模块开发中的作用

    Java中我们一般会使用new关键字实例化对象然后调用该对象所属类提供的方法来实现相应的功能,比如我们现在有个主类叫Web类这个类中能实现各种方法,比如用户注册.发送邮件等功能,代码如下: /* * ...

  2. 毫秒数转换为指定格式日期的js代码

    var format = function(time, format){ var t = new Date(time); var tf = function(i){return (i < 10 ...

  3. SpringJDBC的简单应用

    此处写上应用JdbcTemplate的dao操作数据库的一些代码(含基本的增删改查,注:重点是查询出多条语句的写法): package org.sakaiproject.zhaorui.dao.imp ...

  4. JavaEE填空与判断

    Java EE软件工程师认证考试 试题库- 填空题和选择题   一.     填空题 1. HTML网页文件的标记是__html__,网页文件的主体标记是_body__,标记页面标题的标记是__tit ...

  5. Replace Nested Conditional with Guard Clauses(用卫语句代替嵌套循环)

    函数中的条件逻辑,使人难以看清正常的执行路径. 使用卫语句表现所有特殊情况. double getPayAmount() {double result;if (_isDead) result = de ...

  6. 《Java程序性能优化》学习笔记 程序优化

    这一部分主要介绍代码层的优化.了解如何编写高效而精炼的代码,正确的使用函数方法.1.字符串优化处理Java语言中,String对象可以认为是对char数组的眼神和进一步封装.它主要由3部分组成:cha ...

  7. DbHelper-SQL数据库访问助手

    using System; using System.Data; using System.Data.SqlClient; namespace Whir.Software.Framework.Ulti ...

  8. 利用OData轻易实现串流数据的可视化

    OData(开放数据协议,Open Data Protocol)一直是我喜欢一种的标准(OASIS 标准),它基于RESTful协议提供了一种强大的查询和编辑数据的访问接口.虽然是微软推出的,不过在诞 ...

  9. XTU 1242 Yada Number 容斥

    Yada Number Problem Description: Every positive integer can be expressed by multiplication of prime ...

  10. AngularJS 'Controller As'用法

    AngularJS 1.2版本中提供了Controller As语法,简单说就是可以在Controller中使用this来替代$scope,使得Controller更像一个传统的JS类,相对于$sco ...