博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
winform DataGridView的虚模式填充,CellValueNeeded事件的触发条件
阅读量:5094 次
发布时间:2019-06-13

本文共 2421 字,大约阅读时间需要 8 分钟。

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

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属性),并且这个列必须可见

 

 

 

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

方法使用事例

private void dgvRequisitionDetail_CellValueNeeded(object sender, DataGridViewCellValueEventArgs e)        {            if (e.RowIndex < 0) return;            DataView dv = (DataView)dgvRequisitionDetail.DataSource;            if (dv == null) return;            // RequisitionStatus:请领单状态:0 待审核,1已通过,2未通过,3,已完成(已出库)            if (e.ColumnIndex == CStatus.Index)            {                int status = DbHelper.GetInt(dv[e.RowIndex], "status");                if ((status == (int)RequisitionStatus.TO_AUDIT))                    e.Value = CConst.SetRequisitionStatus(RequisitionStatus.TO_AUDIT);                if ((status == (int)RequisitionStatus.NOTPASS))                    e.Value = CConst.SetRequisitionStatus(RequisitionStatus.NOTPASS);                if ((status == (int)RequisitionStatus.FINISHED))                    e.Value = CConst.SetRequisitionStatus(RequisitionStatus.FINISHED);                if ((status == (int)RequisitionStatus.AUDITED))                    e.Value = CConst.SetRequisitionStatus(RequisitionStatus.AUDITED);                int flag = DbHelper.GetInt(dv[e.RowIndex], "flag");                if (flag == (int)StockNumAndRequisitionNumEnum.STOCKNUM_LACK)//库存数量
<请领数量 { dgvrequisitiondetail.rows[e.rowindex].defaultcellstyle.backcolor="Color.Tomato;" } if (flag="=" (int)stocknumandrequisitionnumenum.stocknum_enough) 库存数量>
=请领数量 { dgvRequisitionDetail.Rows[e.RowIndex].DefaultCellStyle.BackColor = Color.LightGreen; } } }

效果图

 

转载于:https://www.cnblogs.com/wsn1203/p/11579032.html

你可能感兴趣的文章
Node.js & Unix/Linux & NVM
查看>>
UVA11752 The Super Powers —— 数论、枚举技巧
查看>>
P进制转Q进制
查看>>
D3之svg transform 与 css3 transform 区别与联系
查看>>
.NET Oject And Json
查看>>
python学习笔记__Python的安装
查看>>
iOS设置拍照retake和use按钮为中文简体
查看>>
以下内容为Stackoverflow上整理以作纪录
查看>>
工业机器人常用语言---val语言介绍
查看>>
python3的包(package)在centos中的安装地址
查看>>
(3)Deep Learning之神经网络和反向传播算法
查看>>
Java Spring boot 企业微信点餐系统
查看>>
保持长宽比 对背景图像进行修改android:scaleType="fitXY"
查看>>
python-上传下载文件
查看>>
【转】如何解决:Android中 Error generating final archive: Debug Certificate expired on 10/09/18 16:30 的错误...
查看>>
HttpClient短信接口
查看>>
echo print printf() sprintf()区别
查看>>
https阿里云证书购买与apache环境配置
查看>>
21个js 技巧收藏
查看>>
PictureBox滚动条、鼠标中轴滚动
查看>>