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

  • 相关阅读:
    Jar包管理规范
    Base64编码原理与应用
    MySQL 5.7.14安装说明,解决服务无法启动
    idea注册
    Oracle 如何对中文字段进行排序
    SVN错误:Attempted to lock an already-locked dir
    排序算法
    设计模式
    分层
    阿里云
  • 原文地址:https://www.cnblogs.com/2008freestyle/p/2419787.html
Copyright © 2020-2023  润新知