博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C# TextBox中的Validating与Validated事件
阅读量:4204 次
发布时间:2019-05-26

本文共 1261 字,大约阅读时间需要 4 分钟。

原文链接:

  validating事件发生时,值还没有被真正存入,所以是空的,而validated事件发生时,值已经存入,所以能取出。可以用validating事件在值存入之前检验某个先决条件,如果不满足,取消之前的操作,用e.cancel;如果要检验值本身的合法性,使用validated事件在值存入之后得到该字段的值。这也是为什么validated事件的e参数没有cancel的原因,这个时候值已经存入,动作已经完成,无法取消。

  不管是validating还是validated,事件发生的时候控件都没有失去焦点,所以才能对该控件进行操作。控件的事件发生顺序为Enter、GotFocus、Leave、Validating、Validated、LoseFocus,程序焦点先“进入”控件后,控件“得到焦点”,然后焦点“离开”控件,这时焦点在控件内的“动作”还没有存入,于是“校验”,然后存入,存入完成后发生“校验完”事件,善后处理完毕后控件“失去焦点”。

  焦点事件按下列顺序发生:

  Enter // 进入控件时发生
  GotFocus // 控件接收焦点时发生
  Leave // 输入焦点离开控件时发生
  Validating // 控件数据校验时发生
  Validated // 数据检验完成后发生
  LostFocus // 失去焦点时发生

  如果CausesValidation属性设置为false,将取消Validating和Validated事件。

  注:GotFocus和LostFocus事件是关联于WM_KILLFOCUS和WM_SETFOCUS Windows消息的低级别焦点事件。应对所有控件使用Enter和Leave事件。

  如果在Validating事件委托中,CancelEventArgs对象的Cancel属性设置为true,则正常情况下在Validating事件之后发生的所有事件均被取消。

  在操作中要验证控件的内容,可以编写代码来处理Validating事件。在事件处理程序中,测试特定的条件,例如:一个电话号码的TextBox 控件,则可以检查该控件是否只包含适当的字符(数字、括号和连字符等等)。通常,可使用正则表达式验证用户输入的数据。验证是在处理时发生的一系列事件之一。

  如果测试失败,则Validating事件的CancelEventArgs的Cancel属性将设置为true。这将取消Validating事件,并导致焦点返回到控件。实际的结果是,除非数据有效,否则用户将无法退出该控件。

  可以重写验证,并通过创建窗体的Closing事件的处理程序来关闭仍包含无效数据的窗体。在该事件中,将Cancel属性设置为False,这将强制关闭该窗体。

  注意:如果使用此方法强制关闭窗体,控件中尚未保存的任何信息都将丢失。在模式窗体中,仍可以使用控件验证将焦点锁定到控件,而不必考虑关闭窗体的行为,因为模式窗体在关闭时不会验证控件内容。

 

转载地址:http://fpsli.baihongyu.com/

你可能感兴趣的文章
【计算机网络 第五版】阅读笔记之五:运输层
查看>>
【一天一道LeetCode】#77. Combinations
查看>>
【一天一道LeetCode】#78. Subsets
查看>>
【一天一道LeetCode】#79. Word Search
查看>>
【一天一道LeetCode】#81. Search in Rotated Sorted Array II
查看>>
【数据结构与算法】深入浅出递归和迭代的通用转换思想
查看>>
【一天一道LeetCode】#83. Remove Duplicates from Sorted List
查看>>
【一天一道LeetCode】#91. Decode Ways
查看>>
【一天一道LeetCode】#92. Reverse Linked List II
查看>>
【一天一道LeetCode】#93. Restore IP Addresses
查看>>
【一天一道LeetCode】#94. Binary Tree Inorder Traversal
查看>>
【一天一道LeetCode】#113. Path Sum II
查看>>
【一天一道LeetCode】#114. Flatten Binary Tree to Linked List
查看>>
【unix网络编程第三版】阅读笔记(二):套接字编程简介
查看>>
【一天一道LeetCode】#115. Distinct Subsequences
查看>>
【一天一道LeetCode】#116. Populating Next Right Pointers in Each Node
查看>>
【一天一道LeetCode】#117. Populating Next Right Pointers in Each Node II
查看>>
【一天一道LeetCode】#118. Pascal's Triangle
查看>>
【一天一道LeetCode】#119. Pascal's Triangle II
查看>>
【unix网络编程第三版】ubuntu端口占用问题
查看>>