C# DataGridView 的 CellValueChanged 与修改数据没保存的情况

一、概述
    由于DataGridView的逻辑比较复杂,微软在设计它时,有些东西没有考虑全面,并且可能存在一些Bug。这篇文章,就CellValueChanged与数据源的保存这两个问题来谈谈。

二、CellValueChanged
    TextBox这个控件,有一个TextChanged事件,每当文本框中的内容,发生更改,就会立即触发一次该事件。利用该事件,可以完成很多功能,比如自动完成功能。但是,DataGridView,则没有这个事件。首先,DataGridView里的CellValueChanged事件,是在Cell内容被更改,并且焦点移出Cell后才触发。因此,希望做到Cell内容被更改后就立即触发这个事件的朋友,可能就会失望了。我们在这里也没有简单的解决方案来实现这个功能,如果一定要使用这个功能,我们只能推荐绑定按键事件,并在按键事件中去做复杂的逻辑控制。

三、数据更改后没保存到数据源
    这个问题,发生在,使用了BindingNavigator控件。
    首先,BindingNavigator这个控件很方便,如果要使用,需要先设置一个数据源,比如DataSet或DataTable,然后,把DataGridView与BindingNavigator都绑定这个数据源,来实现BindingNavigator对DataGridView的控制。
    其次,目前的问题是,当在DataGridView里完成数据的修改后,点击BindingNavigator上的保存按钮,居然发现数据源并没有被修改。其实,只要你细心观察,就会发现,当你点击BindingNavigator上的保存按钮时,DataGridView的Cell里的焦点仍然存在,也就是那个输入字符的光标。因此,焦点在DataGridView里,就不会发生CellValueChanged事件,因此数据源也不会被修改。
    最后,这个问题有一个解决方案,就是不要把按钮放在BindingNavigator上,而是单独做一个按钮。当在DataGridView里编辑完成后,去点击这个单独的按钮,DataGridView会把焦点给这个按钮,来完成数据源的保存。
    由上分析可见,DataGridView应该对BindingNavigator做了特殊的优化,不然,另一个控件被点击,焦点不可能还停留上上一个控件里,因为这违背用户界面设计的基本原则。

如果有任何问题,请加QQ群 68328977 来进行讨论。
原文地址:https://www.cnblogs.com/xxxteam/p/2851265.html