DataGridView的DataBindingComplete事件困惑
最近用到DataGridView,在绑定完数据库,要根据一定的规则改变DataGridView的列值以及背景颜色,我首先用的是用的视图,从数据库获得一个表,然后赋值给DataGridView,在DataBindingComplete中,对行进行扫描,方法如下:

private void dgvcardoor_DataBindingComplete(object sender, DataGridViewBindingCompleteEventArgs e)
{
DataGridView curDgv = (DataGridView)sender;
foreach (DataGridViewRow Row in curDgv.Rows)
{
if (Row != null)
{
foreach (DataGridViewCell cell in Row.Cells)
{
if (curDgv.Columns[cell.ColumnIndex].DataPropertyName.Equals("IsModify"))
{
if (cell.Value.ToString().Equals("是"))
{
Row.DefaultCellStyle.ForeColor = Color.Blue;
Row.DefaultCellStyle.BackColor = Color.OrangeRed;
}
}
if (curDgv.Columns[cell.ColumnIndex].DataPropertyName.Equals("TopImgUrl"))
{
cell.Value = "俯视图像";
}
if (curDgv.Columns[cell.ColumnIndex].DataPropertyName.Equals("LeftImgUrl"))
{
cell.Value = "左视图像";
}
if (curDgv.Columns[cell.ColumnIndex].DataPropertyName.Equals("RightImgUrl"))
{
cell.Value = "右视图像";
}
}
}
}
}
但是当数据源是DataTable的时候, 改变DataGridView的Cell值,当改变一个值后,会重新触发DataGridView的DataBindingComplete事件,从而进行新的绑定操作,这样就陷入了一个死循环,程序无法执行下去,没有办法,后来改用了list<>,才解决了此问题,在此记录一下,以免以后还会犯类似的错误;
注意:
1. 在WinFrm下的DataGridView控件
2. 改变当前行CurrentRow,在DataGridView_CellClick事件中添加
DataGridView.Rows[e.RowIndex].Selected = true;
3. 在DataGridView里面获得的Cell值是更改后的值,你需要在后台重新的获得你想要的数据;
作者:不老神仙
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
分类:
.NET FrameWork
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· 字符编码:从基础到乱码解决
· SpringCloud带你走进微服务的世界