DataGridView中虚拟模式(Virtual Mode)的使用

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控件加载数据,另一方面,也可以达到数据和显示分离的目的。


posted on 2006-09-17 13:50 马维峰 阅读(4216) 评论(6)  编辑 收藏 所属分类: [06] .net

评论

#1楼  2006-09-17 16:16 neuhawk1 [未注册用户]

有个问题,datagridview不支持表尾合计,很不爽,也不支持二维表头.
自己用gdi画,效果不是很好.   回复  引用    

#2楼  2006-09-17 19:47 moslem [未注册用户]

是 DataGrid 还是 GridView ?

  回复  引用    

#3楼 [楼主] 2006-09-17 20:11 马维峰      

DataGridView 是.NET 2.0 中的一个新控件,是针对.NET 1.x 中功能较差的标准DataGrid 控件而设计的。   回复  引用  查看    

#4楼  2006-09-18 13:55 feilng [未注册用户]

既不是DataGrid也不是GridView
就是Datagridview   回复  引用    

#5楼  2007-01-29 15:12 小荷扬扬 [未注册用户]

您好,请问datagridview的虚拟模式怎么用啊,我都快急死了。希望得到您的帮助,有没有小例子传给我一份.yangkehong2@163.com
  回复  引用    

#6楼  2007-05-20 16:25 frankie [未注册用户]

請參考...只是显示数据...
private void DemoMultiColumnSort_Load(object sender, EventArgs e)
{
this.PersonGrid.CellValueNeeded += new DataGridViewCellValueEventHandler(PersonGrid_CellValueNeeded);
this.PersonGrid.RowCount = 15000;
}

void PersonGrid_CellValueNeeded(object sender, DataGridViewCellValueEventArgs e)
{
Person programmerTmp = this.programmers[e.RowIndex];
switch (e.ColumnIndex)
{
case 0:
e.Value = programmerTmp.ID;
break;
case 1:
e.Value = programmerTmp.LastName;
break;
case 2:
e.Value = programmerTmp.FirstName;
break;
case 3:
e.Value = programmerTmp.Date;
break;
case 4:
e.Value = programmerTmp.Region;
break;
case 5:
e.Value = programmerTmp.Level;
break;
}
}   回复  引用    


标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
 
 


导航

公告

欢迎访问:

联系方式:
  • Email: mweifeng#gmail.com
  • MSN: mimicico#hotmail.com

订阅:
  • 订阅到抓虾

统计

与我联系

搜索

 

常用链接

留言簿(85)

随笔分类(436)

随笔档案(347)

文章分类(34)

文章档案(24)

GIS站点

个人链接

积分与排名

最新随笔

最新评论

阅读排行榜

评论排行榜