• RowChanged()事件,ColumnChanged()事件


    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()方法时,仍会触发行改变事件。

  • 相关阅读:
    Linux之SSH详解
    Linux下的静态路由配置
    Linux之防火墙配置
    五、SQL 转换:Oracle 转 MySQL
    四、Oracle转Mysql总结
    三、MySQL 替代 Oracle 序列以及自增长处理
    二、MySQL 高级部分
    一、MySQL 基础
    15-1、常用类
    14-1、GUI
  • 原文地址:https://www.cnblogs.com/2008freestyle/p/2419787.html
Copyright © 2020-2023  润新知