弗瑞斯达

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: :: 管理 ::

1.RowChanged事件的触发条件:

(1)tbl.Add(row),添加记录时,即行状态由Detached变成Added时会触发;

(2)修改记录值时

(3)调用tbl.AcceptChanges()方法时

(4)删除记录时(指彻底删除,而不是行状态变为Deleted)。

注:1.先执行删除,再执RowChanged事件;即在RowChanged事件之前,行状态已变为Detached。

2.在列改变事件中,执行行的EndEdit()方法,会立即顺序地去执行RowChanging和RowChanged事件,执行完毕后,再转回该列改变事件中继续执行,结束之后会再次顺序地执行RowChanging和RowChanged事件。在修改了字段值和执行RowChanged事件之间,该行的状态不会发生改变,只有在执行RowChanged事件时,访行的状态才会变为Modified。

3.不能在RowChanging事件中调用行的CancelEdit()方法。在ColumnChanging事件和RowChanged中调用行的CancelEdit()方法均不起任何作用。在ColumnChanged事件中调用CancelEdit() 方法会取消编辑,并在该事件结束后,不会执行RowChanging和RowChanged事件。

4.删除记录时并不会触发列改变事件。


2.tbl.ColumnChanged()事件的触发条件:

(1)修改列值时,即使此时行r1的状态为Detached,不是Added。例如,DataRow r1 = tbl.NewRow();r1["编号"] = 1;也会触发

注:tbl.Rows.Add(4, "王小虎", 900);会触发行改变事件,但不会触发列改变事件。

 

3.在编辑表中数据时,即便前后值未改变,焦点离开后仍会触发列改变事件。

4.没有被添加、修改、删除的记录在执行AcceptChanges()方法时,仍会触发行改变事件。

posted on 2012-03-27 16:33  弗瑞斯达  阅读(645)  评论(0编辑  收藏  举报