Číst v angličtině

Sdílet prostřednictvím


Control.LostFocus Událost

Definice

Nastane, když ovládací prvek ztratí fokus.

[System.ComponentModel.Browsable(false)]
public event EventHandler LostFocus;
[System.ComponentModel.Browsable(false)]
public event EventHandler? LostFocus;

Event Type

Atributy

Příklady

Následující příklad kódu ukazuje ověření textu pro TextBox1. Ukazuje také zpracování LostFocus události nastavením FileDialog.InitialDirectory vlastnosti na text v TextBox1. Příklad kódu použil metodu ErrorProvider.GetError ke kontrole chyby před otevřením dialogového okna souboru. Pokud chcete spustit tento příklad, vložte následující kód do formuláře obsahujícího TextBox pojmenované TextBox1, OpenFileDialog pojmenované OpenFileDialog1, pojmenované ButtonButton1a pojmenované ErrorProvider1ErrorProvider . Ujistěte se, že jsou všechny události přidružené k jejich obslužným rutinám událostí.

private void textBox1_Validating(object sender, 
    System.ComponentModel.CancelEventArgs e)
{
    // If nothing is entered,
    // an ArgumentException is caught; if an invalid directory is entered, 
    // a DirectoryNotFoundException is caught. An appropriate error message 
    // is displayed in either case.
    try
    {
        System.IO.DirectoryInfo directory = 
            new System.IO.DirectoryInfo(textBox1.Text);
        directory.GetFiles();
        errorProvider1.SetError(textBox1, "");
    }
    catch(System.ArgumentException ex1)
    {
        errorProvider1.SetError(textBox1, "Please enter a directory");
    }
    catch(System.IO.DirectoryNotFoundException ex2)
    {
        errorProvider1.SetError(textBox1, "The directory does not exist." +
            "Try again with a different directory.");
    }
}

// This method handles the LostFocus event for textBox1 by setting the 
// dialog's InitialDirectory property to the text in textBox1.
private void textBox1_LostFocus(object sender, System.EventArgs e)
{
    openFileDialog1.InitialDirectory = textBox1.Text;
}

// This method demonstrates using the ErrorProvider.GetError method 
// to check for an error before opening the dialog box.
private void button1_Click(System.Object sender, System.EventArgs e)
{
    //If there is no error, then open the dialog box.
    if (errorProvider1.GetError(textBox1)=="")
    {
        DialogResult dialogResult = openFileDialog1.ShowDialog();
    }
}

Poznámky

Když změníte fokus pomocí klávesnice (TAB, SHIFT+TAB atd.), voláním Select metod nebo SelectNextControl nebo nastavením ContainerControl.ActiveControl vlastnosti na aktuální formulář, události fokusu proběhnou v následujícím pořadí:

  1. Enter

  2. GotFocus

  3. Leave

  4. Validating

  5. Validated

  6. LostFocus

Když změníte fokus pomocí myši nebo voláním Focus metody, události fokusu nastanou v následujícím pořadí:

  1. Enter

  2. GotFocus

  3. LostFocus

  4. Leave

  5. Validating

  6. Validated

CausesValidation Pokud je vlastnost nastavena na false, Validating jsou události a Validated potlačeny.

Cancel Pokud je vlastnost nastavena CancelEventArgs na true v delegátu Validating události, všechny události, které by obvykle nastaly po Validating události jsou potlačeny.

Poznámka

Události GotFocus a LostFocus jsou události nízké úrovně fokusu, které jsou vázané na WM_KILLFOCUS a WM_SETFOCUS zpráv systému Windows. GotFocus Události a LostFocus se obvykle používají pouze při aktualizaci UICues nebo při psaní vlastních ovládacích prvků. Enter Místo toho by se události a Leave měly používat pro všechny ovládací prvky s výjimkou Form třídy, která používá Activated události aDeactivate. Další informace o GotFocus událostech a LostFocus najdete v tématech WM_KILLFOCUS a WM_KILLFOCUS .

Upozornění

Nepokoušejte se nastavit fokus z Enterobslužných rutin událostí , LeaveGotFocus, , LostFocusValidating, nebo Validated . To může způsobit, že aplikace nebo operační systém přestanou reagovat. Další informace najdete v tématu WM_KILLFOCUS .

Další informace o zpracování událostí najdete v tématu Zpracování a vyvolávání událostí.

Platí pro

Produkt Verze
.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

Viz také