sort page 排序和分页的小例子

代码如下:

/* 系统名:SaleManage
* 模块名:SortPags
* 模块说明:排序分页类(传入DataTable,及相关信息,然后分页,并排序)
* 开发者:Peter Luo
* 开发时间:2012年4月6日
*/
using System;
using System.Collections.Generic;
using System.Linq;
 using System.Text;
 using System.Data ;

namespace Sale_Core
 {
 public class SortPags
 {
 ///
 /// 存储传入的数据
 ///
 private DataTable _DtSource = null;
 private DataView _DvSource = null;

///
 /// 分页排序类
 ///
 /// 要分页或排序的数据源
 public SortPags(DataTable dt)
 {
 this._DtSource = dt;
 }

///
 /// 分页排序类
 ///
 /// 要分页或排序的数据源
 public SortPags(DataView dv)
 {
 this._DvSource = dv;
 }

///
 /// 页面总数
 ///
 private int _PageCount;

///
 /// 每页记录数量
 ///
 private int _PageSiz;

///
 /// 记录总数
 ///
 private int _RowCount;

///
 /// 排序类型
 /// ASC 升序
 /// DESC 降序
 ///
 private SortType _SortKind;

///
 /// 记录当前页面Index
 ///
 private int _CurrentPageIndex;

///
 /// 数据源
 ///
 public DataTable DtSource
 {
 get
 {
 return _DtSource;
 }
 }

///
 /// 页面数量
 ///
 public int PageCount
 {
 get
 {
 return _PageCount;
 }
 }

///
 /// 页面显示数量
 ///
 public int PageSize
 {
 get
 {
 return _PageSiz;
 }
 set
 {
 _PageSiz = value;
 }
 }

///
 /// 只读、不能写,获取该数据源那数据总数
 ///
 public int RowCount
 {
 get
 {
 return _RowCount;
 }
 }

public SortType SortKind
 {
 get
 {
 return _SortKind;
 }
 set
 {
 _SortKind = value;
 }
 }

///
 /// 记录当前页面Index
 ///
 public int CurrentPageIndex
 {
 get
 {
 return _CurrentPageIndex;
 }
 }

public DataView Sort(string sortName, SortType sortKind)
 {
 return new DataView();
 }

///
 /// 获取按照给定字段分页后的制定页,(排序->分页)
 ///
 /// 传入排序的字段
 /// 排序的类型:SortType.ASC 升序 SortType.DESC 降序
 /// 页面的大小(页面内要显示的记录的数量)
 /// 当前页面的index
 ///
 public DataTable GetCurrentPageSortByFileName(string sortName, SortType sortKind, int pageSize, int currentPageIndex)
 {
 if (pageSize == 0)
 return DtSource;//如果没有填写pagesize那么返回整个数据源
 if (currentPageIndex <= 0)
 return DtSource; //如果没有传入当前页面index,则返回整个数据源
 if (sortName == "")
 return GetCurrentPage(pageSize, currentPageIndex);//如果排序字段没写,则只有分页,不进行排序

DataView dv = new DataView(DtSource);
 switch (sortKind)
 {
 case SortType.DESC :
 dv.Sort = sortName + "DESC";
 break;
 case SortType .ASC :
 dv.Sort = sortName + "ASC";
 break;
 default :
 break;
 }

_PageSiz = pageSize;
 _CurrentPageIndex = currentPageIndex;

this._RowCount = this.DtSource.Rows.Count;
 this._PageCount = this.RowCount / this.PageSize;
 if (_PageCount * PageSize < RowCount) //如果计算出的页面数*页面上的数据量小于记录数,那么页面大小自动+1
 {
 _PageCount++;
 }

int currentBeginRowIndex = pageSize * (currentPageIndex - 1); //当前页面的开始行
 int currentEndRowIndex = pageSize * currentPageIndex - 1;//当前页面的结束行
 DataTable dtRes = _DtSource.Clone(); //复制数据源表结构
 for (int i = currentBeginRowIndex; i <= currentEndRowIndex; i++) //复制当前页面的数据到新的datatable中
 {
 if (i >= DtSource.Rows.Count)
 break; //当前页面的记录小于该页面应该显示的记录时,就只取当前页面中的数据
 DataRow dr = dtRes.NewRow();
 for (int j = 0; j < _DtSource.Columns.Count; j++)
 {
 dr[j] = dv[i][j];
 }
 dtRes.Rows.Add(dr);
 }
 return dtRes;
 }

///
 ///
 ///
 /// 每页面大小(每个页面上记录的数量)
 /// 当前页面索引
 ///
 public DataTable GetCurrentPage(int pageSize, int currentPageIndex)
 {
 if (pageSize ==0)
 {
 return DtSource;//如果没有填写pagesize那么返回整个数据源
 }
 if (currentPageIndex <= 0)
 {
 return DtSource;//如果没有传入当前页面index,则返回整个数据源
 }
 _PageSiz = pageSize;

_CurrentPageIndex = currentPageIndex;
 this._RowCount = this.DtSource.Rows.Count;
 this._PageCount = this.RowCount / this.PageSize;
 if (_PageCount * PageSize < RowCount) //如果计算出的页面数*页面上的数据量小于记录数,那么页面大小自动+1
 _PageCount++;
 int CurrentBeginRowIndex = PageSize * (currentPageIndex - 1); //当前页面的开始行
 int CurrentEndRowIndex = PageSize * currentPageIndex - 1; //当前页面的结束行
 DataView dv;
 if (_DvSource == null)
 dv = new DataView(DtSource);
 else
 dv = _DvSource;
 DataTable dtRes = _DtSource.Clone(); //复制数据源表结构
 for (int i = CurrentBeginRowIndex; i <= CurrentEndRowIndex; i++) //复制当前页面的数据到新的datatable中
 {
 if (i >= DtSource.Rows.Count) break; //当前页面的记录小于该页面应该显示的记录时,就只取当前页面中的数据
 DataRow dr = dtRes.NewRow();
 for (int j = 0; j < _DtSource.Columns.Count; j++)
 {
 dr[j] = dv[i][j];
 }
 dtRes.Rows.Add(dr);
 }
 return dtRes;
 }
 public enum SortType
 {
 ASC, //升序排列
 DESC //倒序排列
 }
 }
 }

(0)

相关推荐

  • sort page 排序和分页的小例子

    复制代码 代码如下: /* 系统名:SaleManage* 模块名:SortPags* 模块说明:排序分页类(传入DataTable,及相关信息,然后分页,并排序)* 开发者:Peter Luo* 开发时间:2012年4月6日*/using System;using System.Collections.Generic;using System.Linq; using System.Text; using System.Data ; namespace Sale_Core { public cl

  • Vue.js实现多条件筛选、搜索、排序及分页的表格功能

    与上篇实践教程一样,在这篇文章中,我将继续从一种常见的功能--表格入手,展示Vue.js中的一些优雅特性.同时也将对filter功能与computed属性进行对比,说明各自的适用场景,也为vue2.0版本中即将删除的部分filter功能做准备. 需求分析 还是先从需求入手,想想实现这样一个功能需要注意什么.大致流程如何.有哪些应用场景. 表格本身是一种非常常用的组件,用于展示一些复杂的数据时表现很好. 当数据比较多时,我们需要提供一些筛选条件,让用户更快列出他们关注的数据. 除了预设的一些筛选条

  • 在ASP.NET 2.0中操作数据之二十六:排序自定义分页数据

    导言 和默认翻页方式相比,自定义分页能提高几个数量级的效率.当我们的需要对大量数据分页的时候就需要考虑自定义分页,然而实现自定义分页相比默认分页需要做更多工作.对于排序自定义分页数据也是这样,在本教程中我们就会扩展前面的例子来实现自定义分页数据的排序. 注意:既然本教程是基于前一个的,因此我们需要把前面教程示例页面EfficientPaging.aspx的<asp:Content>元素中的代码复制到本教程SortParameter.aspx示例页面中.关于如何进行这样的复制操作请参看为删除数据

  • XML创建可排序、分页的数据显示页面

    在Web开发中,我们经常会遇到分页显示和排序数据记录集的情况,这在服务器端使用服务器端的代码和数据库技术是件很轻松的事情,比如:ASP.PHP.JSP等.然而,如果要在客户端显示多条记录并且排序是一件很令人头疼的事情.下面,我们利用Extensible Markup Language(XML,可扩展标记语言)和Extensible Stylesheet Language Transformations(XSLT,可扩展样式单语言转换),并结合XML Path Language(XPath,XML

  • 利用jQuery 实现GridView异步排序、分页的代码

    每次请求备份管理页面时,服务端会把所以的备份还原信息都传到客户端,然后ui.tabs将两种信息折叠起来分别显示,好在ui.tabs给我提供ajax功能,我们的每个tab可以直接应用另外一个页面 如: 复制代码 代码如下: <div id="container"> <ul> <li><a href="#fragment-1"><span>备份</span></a></li>

  • JS中sort函数排序用法实例分析

    本文实例讲述了JS中sort函数排序用法.分享给大家供大家参考,具体如下: 最近遇到了一个面试题目,关于排序的问题,为了完善自己的知识点,这里就写一下学习笔记 <html> <head> <TITLE>class_obj_js_class</TITLE> <script language=javaScript> //sort()方法默认是按照ASCII码大小排序,看下面两个例子 function sortDemo(){ var a, l; //

  • Python Django实现layui风格+django分页功能的例子

    第一步:首先定义一个视图函数,用于提供数据,实现每页显示数据个数,返回每页请求数据 from django.shortcuts import render from django.core.paginator import Paginator # Django内置分页功能模块 def index(request): # 提供json数据 resp = {"id":10000,"username":"user-0","sex":

  • 100 个 Python 小例子(练习题三)

    目录 实例051:按位与 实例052:按位或 实例053:按位异或 实例054:位取反.位移动 实例055:按位取反 实例056:画圈 实例057:画线 实例058:画矩形 实例059:画图(丑) 实例060:字符串长度 例061:杨辉三角 实例062:查找字符串 实例063:画椭圆 实例64:画椭圆.矩形 实例065:画组合图形 实例066:三数排序 实例067:交换位置 实例068:旋转数列 实例069:报数 实例070:字符串长度II 实例071:输入和输出 实例072:创建链表 实例07

  • 100 个 Python 小例子(练习题四)

    目录 实例076:做函数 实例077:遍历列表 实例078:字典 例079:字符串排序 实例080:猴子分桃 实例081:求未知数 实例082:八进制转十进制 实例083:制作奇数 实例084:连接字符串 实例085:整除 实例086:连接字符串II 实例087:访问类成员 实例088:打印星号 实例089:解码 实例090:列表详解 实例091:time模块 实例092:time模块II 实例093:time模块III 实例094:time模块IV 实例095:转换时间格式 实例096:计算复

  • Spring Data JPA实现排序与分页查询超详细流程讲解

    目录 前言 1.创建持久化实体类 2.创建数据访问层 3.创建业务层 4.创建控制器类 5.创建View视图页面 6.运行主类 效果如下 前言 在实际开发场景中,排序与分页查询是必须的,幸运的是Spring Data JPA充分考虑了排序与分页查询的场景,为我们提供Sort类 Page接口 Pageable接口 下面通过一个实战来阐明 1.创建持久化实体类 创建名为com.ch.ch6_4.entity的包 并在该包中创建名为Article和Author的持久化实体类 代码如下 Article

随机推荐