【转载】DataGridView中虚拟模式(Virtual Mode)用法

摘要:
对于某些特殊情况,我们需要自己填写DataGridView。此时,我们只需要先根据行和列的顺序获取行,然后通过行的cell属性获取单元格,并设置其Value属性。对于DataGridView,一切就绪。只要我们启动VirtualMode并实现几个事件,DataGridView就会为我们做其他事情。将DataGridView控件添加到WinForm表单,并将VirtualMode属性设置为True。总之,使用虚拟模式一方面可以很好地加载DataGridView控件的数据,另一方面也可以实现数据和显示的分离。底部是将DataTable绑定到DataGridView。

DataGridView是.net 2.0新增的表格数据编辑和显示控件,简单的数据显示和编辑,只需直接和数据源绑定就可以了。
    对于 一些特殊情况,我们需要自己填充DataGridView,这时候只需要按照行列顺序,首先获得行,然后通过行的Cells属性,得到单元格,设置其 Value属性即可。但这种模式有个问题,即对于几十行或者几百行的数据,显示效率不是问题,当数据量逐渐增大时,效率就成了一个非常重要的问题。
    那么,如何解决这样的问题呢,写过或者看过类似Grid控件的朋友一定会想到,按需加载数据。也就是当我们在数据表格中移动时,显示到屏幕上的数据只是实际 需要的数据的一部分,那么,只加载这部分数据即可。而对于DataGridView,一切都准备好了,只要我们开启VirtualMode,然后实现几个 事件(用于加载保存数据),其他的事情DataGridView会替我们做好。
    在WinForm窗体中添加一个DataGridView控件,设置VirtualMode属性为True。

实现如下事件:
    第一个需要实现的事件是:CellValueNeeded,该事件在控件刷新,需要为单元格填充数据时发生,其参数e返回当前单元格的行和列,根据行和列,获取需要的值,赋给e的Value属性。
    如果只是显示数据,该事件已足够,从理论上,通过这样的方法,DataGridView显示的数据与数据量无关,即使数据量再大,也可以在常数时间内完成刷新。
    第二个需要实现的事件是CellValuePushed,该事件在一个单元格编辑完成后触发,将数据写回数据源。其中事件的参数e会返回单元格的行、列、值。
    如果要添加行和删除行,则需要实现NewRowNeeded和UserDeletingRow事件。还有其他一些事件,来控制放弃单元格、行的编辑等事件。具体可以参考帮助文档。
    总之,使用虚拟模式,一方面可以很好的为DataGridView控件加载数据,另一方面,也可以达到数据和显示分离的目的。

    转自:http://www.cnblogs.com/maweifeng/archive/2006/09/17/506574.html

案例:

     绑定数据到DataGridView上。

    下边代码中的dgvWage为DataGridView。本例在加载时要显示数据,所以在加载时取出资料,保存到dtWork中,但不绑定到DataGridView上。只设置DataGridView的RowCount属性。

        DataTable dtWork = null;
private void FrmCountWage_Load(object sender, EventArgs e)
        {
            GetWorkDayByDate(DateTime.Now);
        }
//得到数据,
private void GetWorkDayByDate()
        {
string sql = @"SELECT * from xx";
            sql = string.Format(sql, date.ToString("yyyy-MM-dd"));
            dtWork = dal.GetDatatableData(sql);
//不使用绑定数据,绑定在 CellValueNeeded事件中处理
//dgvWage.DataSource = dtWork;
//设置DataGridView的行数
            dgvWage.RowCount = dtWork.Rows.Count;
        }

在CellValueNeeded事件是绑定数据。CellValueNeeded是一格一格将数据设置上去了,而且暂时不需要的数据不设置。下边为绑定DataTable到DataGridView上。

private void dgvWage_CellValueNeeded(object sender, DataGridViewCellValueEventArgs e)
        {
if (e.RowIndex==dgvWage.RowCount)
            {
return;
            }
// 从记录集中读取数据  
string colName = dgvWage.Columns[e.ColumnIndex].DataPropertyName;
            e.Value = dtWork.Rows[e.RowIndex][colName].ToString();
        }

这样Virtual Mode用法介绍完成。

免责声明:文章转载自《【转载】DataGridView中虚拟模式(Virtual Mode)用法》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇H5基于iScroll实现下拉刷新,上拉加载更多delphi 屏幕截屏下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

devexpress实现单元格合并以及依据条件合并单元格

1、devexpress实现单元格合并非常的简单,只要设置属性【AllowCellMerge=True】就可以了,实现效果如下图: 2、但是在具体要求中并非需要所有的相同单元格都合并,可能需要其他的条件来控制合并。这个时候我们就需要在事件gridView1_CellMerge中来控制了。下图为根据最后一列判断是否合并单元格的效果图(其中第四列设置为不合并&...

网上看到的比较全的关于C#操作EXCEL常见操作集合,比较全,写的不错

原文地址:http://hi.baidu.com/kjkj911/blog/item/0ecc3ec7855dd6d4d100600f.html private _Workbook _workBook = null; private Worksheet _workSheet = null; private Excel.Application _excelA...

ASP操作Excel技术总结

目录一、环境配置二、ASP对Excel的基本操作三、ASP操作Excel生成数据表四、ASP操作Excel生成Chart图五、服务器端Excel文件浏览、下载、删除方案六、附录正文一、环境配置服务器端的环境配置从参考资料上看,微软系列的配置应该都行,即:1.Win9x+PWS+Office2.Win2000Professional+PWS+Office3....

Grid布局

什么是Grid布局? 将网页分为一个个网格,对网格进行不同的操作,实现不同的效果 容器 采用网格布局的区域 项目 网格内部采用网格定位的元素,称为项目。项目只能是容器的顶层子元素 行和列 容器中的水平区域称为行row,垂直区域称为列column 单元格 行和列的交叉区域,称为单元格cell 网格线 划分网格的线,称为网格线grid line n行有n+1条...

JXL操作Excel

      jxl是一个韩国人写的java操作excel的工具, 在开源世界中,有两套比较有影响的API可 供使用,一个是POI,一个是jExcelAPI。其中功能相对POI比较弱一点。但jExcelAPI对中文支持非常好,API是纯Java的, 并不 依赖Windows系统,即使运行在Linux下,它同样能够正确的处理Excel文件。 另外需要说明的是,...

C#操作Excel时,Excel常用的方法和属性zz

生成excel的时候有时候需要设置单元格的一些属性,可以参考一下:range.NumberFormatLocal="@";//设置单元格格式为文本 range=(Range)worksheet.get_Range("A1","E1");//获取Excel多个单元格区域:本例做为Excel表头 range.Merge(0);//单元格合并动作 works...