Control.Validating Olay

Tanım

Denetim doğrulanırken gerçekleşir.

C#
public event System.ComponentModel.CancelEventHandler Validating;
C#
public event System.ComponentModel.CancelEventHandler? Validating;

Olay Türü

Örnekler

Aşağıdaki kod örneği türetilmiş sınıfını TextBox kullanır ve kullanıcının girdiği bir e-posta adresini doğrular. E-posta adresi standart biçimde değilse ("@" ve ".") doğrulama başarısız olur, bir ErrorProvider simge görüntülenir ve olay iptal edilir. Bu örnek, formda bir TextBox ve ErrorProvider denetiminin oluşturulmasını gerektirir.

C#
private void textBox1_Validating(object sender, 
                System.ComponentModel.CancelEventArgs e)
{
   string errorMsg;
   if(!ValidEmailAddress(textBox1.Text, out errorMsg))
   {
      // Cancel the event and select the text to be corrected by the user.
      e.Cancel = true;
      textBox1.Select(0, textBox1.Text.Length);

      // Set the ErrorProvider error with the text to display. 
      this.errorProvider1.SetError(textBox1, errorMsg);
   }
}

private void textBox1_Validated(object sender, System.EventArgs e)
{
   // If all conditions have been met, clear the ErrorProvider of errors.
   errorProvider1.SetError(textBox1, "");
}
public bool ValidEmailAddress(string emailAddress, out string errorMessage)
{
   // Confirm that the email address string is not empty.
   if(emailAddress.Length == 0)
   {
      errorMessage = "email address is required.";
         return false;
   }

   // Confirm that there is an "@" and a "." in the email address, and in the correct order.
   if(emailAddress.IndexOf("@") > -1)
   {
      if(emailAddress.IndexOf(".", emailAddress.IndexOf("@") ) > emailAddress.IndexOf("@") )
      {
         errorMessage = "";
         return true;
      }
   }
   
   errorMessage = "email address must be valid email address format.\n" +
      "For example 'someone@example.com' ";
      return false;
}

Açıklamalar

Odağı klavye kullanarak (SEKME, SHIFT+SEKME vb.) değiştirdiğinizde, veya SelectNextControl yöntemlerini çağırarak Select veya özelliğini geçerli forma ayarlayarak ContainerControl.ActiveControl odak olayları aşağıdaki sırayla gerçekleşir:

  1. Enter

  2. GotFocus

  3. Leave

  4. Validating

  5. Validated

  6. LostFocus

Fareyi kullanarak veya yöntemini çağırarak Focus odağı değiştirdiğinizde, odak olayları aşağıdaki sırayla gerçekleşir:

  1. Enter

  2. GotFocus

  3. LostFocus

  4. Leave

  5. Validating

  6. Validated

CausesValidation özelliği olarak falseValidating ayarlanırsa ve Validated olayları gösterilmez.

Cancel özelliği CancelEventArgs olay temsilcisinde Validating olarak ayarlanırsatrue, genellikle olaydan sonra gerçekleşecek tüm olaylar gizlenırValidating.

Dikkat

Odağı , , GotFocus, Leave, LostFocus, Validatingveya Validated olay işleyicilerinin içinden Enterayarlamayı denemeyin. Bunu yapmak, uygulamanızın veya işletim sisteminizin yanıt vermeyi durdurmasına neden olabilir. Daha fazla bilgi için, "Klavye Girişi Başvurusu" bölümündeki konuya ve İletiler ve İleti Kuyrukları Hakkında makalesinin "İleti Kilitlenmeleri" bölümüne bakınWM_KILLFOCUS.

Olayları işleme hakkında daha fazla bilgi için bkz. Olayları İşleme ve Oluşturma.

Şunlara uygulanır

Ürün Sürümler
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9, 10

Ayrıca bkz.