为什么DataGridView的CurrentCellChanged事件会重复执行两次?

xoceco 2009-02-27 08:06:37
Public CN As New OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=E:\Dbase.mdb;Persist Security Info=True;Jet OLEDB:Database Password=123")
Public ds As DataSet = New DataSet() '所有的数据集


Private Sub Form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load

DataGridView1.DataSource = BindingSource1
Dim myCommand As OleDb.OleDbDataAdapter = New OleDb.OleDbDataAdapter("select * from 工作台帐视图", CN)
myCommand.Fill(ds, "主查询结果")
BindingSource1.DataSource = ds.Tables("主查询结果")

End Sub

Private Sub DataGridView1_CurrentCellChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles DataGridView1.CurrentCellChanged
'此过程会被执行两次,换成SelectionChanged事件过程也一样
Debug.Print(2)
End Sub



Load过程中,执行到BindingSource1.DataSource = ds.Tables("主查询结果")这句时,CurrentCellChanged过程回反复执行两次,非常奇怪!请高手看下,是什么原因?在线等!
...全文
965 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
manan008 2012-07-05
  • 打赏
  • 举报
回复
让我学学
hulishilianle 2011-04-01
  • 打赏
  • 举报
回复
这样的确不错。学到。感谢
CZwei 2010-05-01
  • 打赏
  • 举报
回复
看看 学习下
lishaoyu 2009-03-15
  • 打赏
  • 举报
回复
我采用了Going1981的建议,恩,确实正确的。
仔细回味了他的做法,觉得有意思,就写点心得。
他的核心就是必须让绑定完成以后,才去执行Debug.Print(2)
其实事件还是发送了两次,只不过在事件代码中只执行了一次Debug.Print(2)
binded就像一个开关一样,只有只有绑定完成后,才去响应Debug.Print(2)

lishaoyu 2009-03-15
  • 打赏
  • 举报
回复
我采用了Going1981的建议,恩,确实正确的。
仔细回味了他的做法,觉得有意思,就写点心得。
他的核心就是必须让绑定完成以后,才去执行Debug.Print(2)
其实事件还是发送了两次,只不过在事件代码中只执行了一次Debug.Print(2)
binded就像一个开关一样,只有只有绑定完成后,才去响应Debug.Print(2)

xoceco 2009-02-27
  • 打赏
  • 举报
回复
成功!谢谢大家,给分!
一只熊猫 2009-02-27
  • 打赏
  • 举报
回复
上面的代码就是让DataGridView在绑定数据前不响应SelectionChanged事件,绑定完成后才会响应。
xoceco 2009-02-27
  • 打赏
  • 举报
回复
to:Going1981
这个办法在窗体加载的时候可以,问题是我主要是用在用户单击了dagagridview中的某一行后,当前行发生了改变,需要进行一些操作.
一只熊猫 2009-02-27
  • 打赏
  • 举报
回复
另,最好用SelectionChanged,这样同一行的多次点击不会反复触发事件。
一只熊猫 2009-02-27
  • 打赏
  • 举报
回复
public binded as boolean = false

Private Sub Form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load

DataGridView1.DataSource = BindingSource1
Dim myCommand As OleDb.OleDbDataAdapter = New OleDb.OleDbDataAdapter("select * from 工作台帐视图", CN)
myCommand.Fill(ds, "主查询结果")
BindingSource1.DataSource = ds.Tables("主查询结果")
binded=true

End Sub

Private Sub DataGridView1_CurrentCellChanged(ByVal sender As Object, ByVal e As System.EventArgs) Handles DataGridView1.CurrentCellChanged
'此过程会被执行两次,换成SelectionChanged事件过程也一样
if binded then
Debug.Print(2)
endif
End Sub
xoceco 2009-02-27
  • 打赏
  • 举报
回复
有什么办法解决?因为datagridview中的当前行发生改变后,我只需要执行一次CurrentCellChanged事件过程
wuyq11 2009-02-27
  • 打赏
  • 举报
回复
绑定前执行一次,绑定后执行一次
king19840811 2009-02-27
  • 打赏
  • 举报
回复
初始化一次。绑定数据一次。
vb.net操作DataGridView控件的用法的集合,包括: 1. DataGridView当前的单元格属性取得、变更 2. DataGridView编辑属性 3. DataGridView最下面一列新追加行非表示 4. DataGridView判断当前选中行是否为新追加的行 5. DataGridView删除行可否设定 6. DataGridView行列不表示和删除 DataGridView控件用法合集(二) 7. DataGridView行列宽度高度设置为不能编辑 8. DataGridView行高列幅自动调整 9. DataGridView指定行列冻结 10. DataGridView列顺序变更可否设定 11. DataGridView行复数选择 12. DataGridView选择的行、列、单元格取得 DataGridView控件用法合集(三) 13. DataGridView指定单元格是否表示 14. DataGridView表头部单元格取得 15. DataGridView表头部单元格文字列设定 16. DataGridView选择的部分拷贝至剪贴板 17.DataGridView粘贴 18. DataGridView单元格上ToolTip表示设定(鼠标移动到相应单元格上时,弹出说明信息) DataGridView控件用法合集(四) 19. DataGridView中的ContextMenuStrip属性 20. DataGridView指定滚动框位置 21. DataGridView手动追加列 22. DataGridView全体分界线样式设置 23. DataGridView根据单元格属性更改显示内容 24. DataGridView新追加行的行高样式设置る 25. DataGridView新追加行单元格默认值设置 DataGridView中输入错误数据的处理(五) 26. DataGridView单元格数据错误标签表示 27. DataGridView单元格内输入值正确性判断 28. DataGridView单元格输入错误值事件的捕获 DataGridView控件用法合集(六) 29. DataGridView行排序(点击列表头自动排序的设置) 30. DataGridView自动行排序(新追加值也自动排序) 31. DataGridView自动行排序禁止情况下的排序 32. DataGridView指定列指定排序 DataGridView控件用法合集(七) 33. DataGridView单元格样式设置 34. DataGridView文字表示位置的设定 35. DataGridView单元格内文字列换行 36. DataGridView单元格DBNull值表示的设定 37. DataGridView单元格样式格式化 38. DataGridView指定单元格颜色设定 39. DataGridView单元格文字字体设置 40. DataGridView根据单元格值设定单元格样式 DataGridView控件用法合集(八) 41. DataGridView设置单元格背景颜色 42. DataGridView行样式描画 43. DataGridView显示行号 44. DataGridView焦点所在单元格焦点框不显示的设定 DataGridView控件用法合集(九) 45. DataGridView中显示选择框CheckBox 46. DataGridView中显示下拉框ComboBox 47. DataGridView单击打开下拉框 48. DataGridView中显示按钮 49. DataGridView中显示链接 50. DataGridView中显示图像 DataGridView控件用法合集(十) 51. DataGridView编辑中单元格控件取得 52. DataGridView输入自动完成 53. DataGridView单元格编辑时键盘KEY事件取得 54. DataGridView下拉框(ComboBox)单元格编辑时事件取得 55. DataGridView下拉框(ComboBox)单元格允许文字输入设定 DataGridView控件用法合集(十一) 56. DataGridView根据值不同在另一列中显示相应图片 57. DataGridView中显示进度条(ProgressBar) 58. DataGridView中添加MaskedTextBox DataGridView控件用法合集(十二) 59. DataGridView中Enter键按下焦点移至旁边的单元格 60. DataGridView行集合化(Group)

16,554

社区成员

发帖
与我相关
我的任务
社区描述
VB技术相关讨论,主要为经典vb,即VB6.0
社区管理员
  • VB.NET
  • 水哥阿乐
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧