http://blog.csdn.net/educast/article/details/4769457

evExpress是一套第三方控件

其中有类似DataGridView的控件

今天把针对DevExpress.XtraGrid.GridControl实时加载数据的功能开发出来了

分享给大家

欢迎讨论

Code
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Data;
using DevExpress.XtraGrid;
using DevExpress.XtraGrid.Views.Grid;
namespace Life365.CallCenter
{
public class GridCreator<T> where T: new()
    {
//一页有多少条数据
private int page_size = 30;
public int PageSize
        {
get { return page_size; }
        }
/// <summary>
/// 过滤条件
/// </summary>
public string Filter
        {
get;
set;
        }
/// <summary>
/// 排序条件
/// </summary>
public string OrderBy
        {
get;
set;
        }
/// <summary>
/// 数据访问类
/// </summary>
public BaseProxy Proxy
        {
get;
set;
        }
private int row_count;
/// <summary>
/// 总行数
/// </summary>
public int RowCount
        {
get {return row_count;}
        }
private int page_num = 1;
/// <summary>
/// 当前的数据页
/// </summary>
public int PageNum
        {
get { return page_num; }
        }
//缓存的数据
private List<T> data_list = new List<T>();
private GridCreator()
        { 
        }
/// <summary>
/// 构造函数
/// </summary>
public GridCreator(GridControl grid,BaseProxy proxy)
        {
            ((GridView)grid.MainView).TopRowChanged += new EventHandler(grid_TopRowChanged);
this.Proxy = proxy;
            grid.DataSource = data_list;
        }
/// <summary>
/// 获取前两页数据
/// </summary>
private void GetTwoPageData()
        {
            data_list.InsertRange(0, GetData());
            page_num++;
            data_list.InsertRange(page_size, GetData());
        }        
/// <summary>
/// grid下拉事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
void grid_TopRowChanged(object sender, EventArgs e)
        {
            GridView grid = sender as GridView;
if (grid.TopRowIndex >= (page_num - 1) * page_size)
            {
//当看完一页数据的时候开始取数据
                page_num++;
                List<T> test = GetData();
                data_list.InsertRange((page_num - 1)* page_size, test);
            }
        }
/// <summary>
/// 实时的加载数据函数
/// </summary>
/// <returns></returns>
public List<T> GetData()
        {
return Proxy.GetDataList(this.Filter, this.OrderBy, this.page_size,this.page_num, ref this.row_count) as List<T>;
        }
    }
}

T泛型约束是需要加载数据的类型

BaseProxy是访问数据库的基类,其中包含GetDataList的虚方法

继承自BaseProxy的GetDataList为

Code
public override object GetDataList(string filter, string order_by, int page_size, int page_num, ref int count)
        {
            count = 1000;
            List<RegionEntity> regions = new List<RegionEntity>();
for (int i = 0; i < page_size; i++)
            {
                regions.Add(new RegionEntity() { SR_RegionName = ((page_num-1)*page_size+i).ToString() });
            }
return regions;
        }

这里的RegionEntity就是前面提到的某一种类型的T

数据提供程序是模拟出来的(测试驱动开发,哈哈)

你可以在这个函数里写数据库访问方法

具体调用方法如下

Code
GridCreator<RegionEntity> creator = new GridCreator<RegionEntity>(gridShop,new UtilsProxy());

UtilsProxy类继承自BaseProxy并重写了GetDataList方法

gridShop就是当前窗体的DevExpress.XtraGrid.GridControl控件

RegionEntity针对泛型类型

用起来还是蛮方便的

DevExpress的GridControl的实时加载数据解决方案(取代分页)的更多相关文章

  1. Java Web SpringMVC AJAX,实现页面懒加载数据

    因为做的微信端的网页,所以在显示后台数据的时候,要么分页,要么全部加载数据,开始分页对于用户来说,其实体验不是很好,毕竟要去不断的点击下一页,但是如果我把全部数据读取出来的话,但用户可能也就看前面几条 ...

  2. JPA数据懒加载LAZY和实时加载EAGER(二)

    懒加载LAZY和实时加载EAGER的概念,在各种开发语言中都有广泛应用.其目的是实现关联数据的选择性加载,懒加载是在属性被引用时,才生成查询语句,抽取相关联数据.而实时加载则是执行完主查询后,不管是否 ...

  3. JPA数据懒加载LAZY和实时加载EAGER(转)

    原文:https://www.cnblogs.com/MrSi/p/8081811.html 懒加载LAZY和实时加载EAGER的概念,在各种开发语言中都有广泛应用.其目的是实现关联数据的选择性加载, ...

  4. java攻城狮之路(Android篇)--widget_webview_metadata_popupwindow_tabhost_分页加载数据_菜单

    一.widget:桌面小控件1 写一个类extends AppWidgetProvider 2 在清单文件件中注册: <receiver android:name=".ExampleA ...

  5. iOS开发——网络Swift篇&NSURLSession加载数据、下载、上传文件

    NSURLSession加载数据.下载.上传文件   NSURLSession类支持三种类型的任务:加载数据.下载和上传.下面通过样例分别进行介绍.   1,使用Data Task加载数据 使用全局的 ...

  6. Swift - 使用NSURLSession加载数据、下载、上传文件

    NSURLSession类支持三种类型的任务:加载数据.下载和上传.下面通过样例分别进行介绍. 1,使用Data Task加载数据 使用全局的sharedSession()和dataTaskWithR ...

  7. 新手教程:不写JS,在MIP页中实现异步加载数据

    从需求谈起:在 MIP 页中异步加载数据 MIP(移动网页加速器) 的 加速原理 除了靠谱的 MIP-Cache CDN 加速外,最值得一提的就是组件系统.所有 JS 交互都需要使用 MIP 组件实现 ...

  8. echarts官网上的动态加载数据bug被我解决。咳咳/。

    又是昨天,为什么昨天发生了这么多事.没办法,谁让我今天没事可做呢. 昨天需求是动态加载数据,画一个实时监控的折线图.大概长这样. 我屁颠屁颠的把代码copy过来,一运行,caocaocao~bug出现 ...

  9. js中对arry数组的各种操作小结 瀑布流AJAX无刷新加载数据列表--当页面滚动到Id时再继续加载数据 web前端url传递值 js加密解密 HTML中让表单input等文本框为只读不可编辑的方法 js监听用户的键盘敲击事件,兼容各大主流浏览器 HTML特殊字符

    js中对arry数组的各种操作小结   最近工作比较轻松,于是就花时间从头到尾的对js进行了详细的学习和复习,在看书的过程中,发现自己平时在做项目的过程中有很多地方想得不过全面,写的不够合理,所以说啊 ...

随机推荐

  1. jcaptcha sample 制作验证码

    Skip to end of metadata Created by marc antoine garrigue, last modified by Jeremy Waters on Feb 23, ...

  2. Mysql如何创建短索引(前缀索引)

    Mysql如何创建短索引 为什么要用短索引 有时需要索引很长的字符列,它会使索引变大并且变慢.一个策略就是模拟哈希索引.但是有时这也不够好,那么应该怎么办呢?通常可以索引开始的几个字符,而不是全部值, ...

  3. python的正则表达式

    1 元字符: 1.1 . .除了换行符以外的任何单个字符 1.2 ^ ^只匹配起始字符 temp1=re.findall('^morra','nsudi werwuirnmorra') temp2=r ...

  4. <<< Java生成Md5

    package cn.sevennight.test; import java.security.MessageDigest; public class md5{ public static Stri ...

  5. 使用Spring进行统一日志管理 + 统一异常管理

    http://blog.csdn.net/king87130/article/details/8011843原文地址 统一日志异常实现类: 1 package com.pilelot.web.util ...

  6. 《JavaScript DOM编程艺术(第二版)》读书总结

    这本书是一本很基础的书,但对于刚入前端不久的我来说是一本不错的书,收获还是很大的,对一些基础的东西理解得更加透彻了. 1.DOM即document object model的缩写,文档对象模型,Jav ...

  7. Windows综合应用

    待修改中-------------------------------------- 快捷键部分: Win+E:打开"我的电脑"E:Explot的缩写,即资源管理器. ------ ...

  8. no module named flask.ext.login

    在用安装了flask-login后使用时发现了问题,查了许多资料尝试了许多办法: 1.以为是文件结构的问题,因为flask-login包中没有__init__.py结果编译后还是不行 2.以为是路径问 ...

  9. Fedora 23安装 NS2 (network simulator 2)

    1 实验环境 OS: Fedora 23 workstation 2 实验步骤 ( 参考了:http://www.isi.edu/nsnam/ns/ns-build.html) 本次实验的实验环境: ...

  10. 自动化运维工具Ansible详细部署 (转载)

    自动化运维工具Ansible详细部署 标签:ansible 原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://sofar.blog. ...