经验分享 · 2023年3月2日

winform DataGridView及SunUI的UIDataGridView的虚模式填充,CellValueNeeded事件不触发问题解决

虚模式填充常用来处理大量数据,某个字段的显示问题。

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

CellValueNeeded,该事件在控件刷新,需要为单元格填充数据时发生,其参数e返回当前单元格的行和列,根据行和列,获取需要的值,赋给e的Value属性。
如果只是显示数据,该事件已足够,从理论上,通过这样的方法,DataGridView显示的数据与数据量无关,即使数据量再大,也可以在常数时间内完成刷新。

CellValueNeeded事件触发有两个条件:

1、datagridview的VirtualMode属性要设置为true

2、datagridview的CellValueNeeded事件要触发必须datagridview的列是非绑定列(即不能设置datagridview的DataPropertyName属性),并且这个列必须可见

===============================================================================

方法使用事例