Control.Leave Control.Leave Control.Leave Control.Leave Event

定義

入力フォーカスがコントロールを離れると発生します。Occurs when the input focus leaves the control.

public:
 event EventHandler ^ Leave;
public event EventHandler Leave;
member this.Leave : EventHandler 
Public Custom Event Leave As EventHandler 

次のコード例ではLeave 、イベントを使用して、コントロールを元の状態にリセットします。The following code example uses the Leave event to reset a control to its former state.

private:
   void textBox1_Enter( Object^ /*sender*/, System::EventArgs^ /*e*/ )
   {
      // If the TextBox contains text, change its foreground and background colors.
      if ( textBox1->Text != String::Empty )
      {
         textBox1->ForeColor = Color::Red;
         textBox1->BackColor = Color::Black;

         // Move the selection pointer to the end of the text of the control.
         textBox1->Select(textBox1->Text->Length,0);
      }
   }

   void textBox1_Leave( Object^ /*sender*/, System::EventArgs^ /*e*/ )
   {
      // Reset the colors and selection of the TextBox after focus is lost.
      textBox1->ForeColor = Color::Black;
      textBox1->BackColor = Color::White;
      textBox1->Select(0,0);
   }
private void textBox1_Enter(object sender, System.EventArgs e)
{
    // If the TextBox contains text, change its foreground and background colors.
    if (!string.IsNullOrEmpty(textBox1.Text))
    {
        textBox1.ForeColor = Color.Red;
        textBox1.BackColor = Color.Black;
        // Move the selection pointer to the end of the text of the control.
        textBox1.Select(textBox1.Text.Length, 0);
    }
}

private void textBox1_Leave(object sender, System.EventArgs e)
{
    // Reset the colors and selection of the TextBox after focus is lost.
    textBox1.ForeColor = Color.Black;
    textBox1.BackColor = Color.White;
    textBox1.Select(0,0);
}
    Private Sub textBox1_Enter(sender As Object, e As System.EventArgs) Handles textBox1.Enter
        ' If the TextBox contains text, change its foreground and background colors.
        If textBox1.Text <> [String].Empty Then
            textBox1.ForeColor = Color.Red
            textBox1.BackColor = Color.Black
            ' Move the selection pointer to the end of the text of the control.
            textBox1.Select(textBox1.Text.Length, 0)
        End If
    End Sub 'textBox1_Enter
   
   
    Private Sub textBox1_Leave(sender As Object, e As System.EventArgs) Handles textBox1.Leave
        ' Reset the colors and selection of the TextBox after focus is lost.
        textBox1.ForeColor = Color.Black
        textBox1.BackColor = Color.White
        textBox1.Select(0, 0)
    End Sub 'textBox1_Leave
End Class 'Form1 

注釈

キーボード (タブ、SHIFT + TAB など) を使用してフォーカスを変更した場合、メソッドSelectまたはSelectNextControlメソッドを呼び出すか、 ContainerControl.ActiveControlプロパティを現在のフォームに設定した場合、フォーカスイベントは次の順序で発生します。When you change the focus by using the keyboard (TAB, SHIFT+TAB, and so on), by calling the Select or SelectNextControl methods, or by setting the ContainerControl.ActiveControl property to the current form, focus events occur in the following order:

  1. Enter

  2. GotFocus

  3. Leave

  4. Validating

  5. Validated

  6. LostFocus

マウスを使用するか、 Focusメソッドを呼び出すことによってフォーカスを変更すると、フォーカスイベントは次の順序で発生します。When you change the focus by using the mouse or by calling the Focus method, focus events occur in the following order:

  1. Enter

  2. GotFocus

  3. LostFocus

  4. Leave

  5. Validating

  6. Validated

プロパティがにfalse設定されているValidating場合Validated 、イベントとイベントは抑制されます。 CausesValidationIf the CausesValidation property is set to false, the Validating and Validated events are suppressed.

注意

イベントとイベントLeaveは、クラスによって抑制されます。Form EnterThe Enter and Leave events are suppressed by the Form class. クラスの同等のイベントDeactivate は、イベントとイベントです。Activated FormThe equivalent events in the Form class are the Activated and Deactivate events. イベントEnterLeaveイベントは階層構造であり、適切なコントロールに到達するまで親チェーンを上下に重ねて表示されます。The Enter and Leave events are hierarchical and will cascade up and down the parent chain until the appropriate control is reached. たとえばForm 、に2つGroupBoxのコントロールがあり、各GroupBoxコントロールに1つTextBoxのコントロールがあるとします。For example, assume you have a Form with two GroupBox controls, and each GroupBox control has one TextBox control. カーソルをTextBox 1 つから別のLeave位置に移動すると、 TextBoxGroupBoxのイベントが発生しEnter 、他GroupBoxのとTextBoxに対してイベントが発生します。When the caret is moved from one TextBox to the other, the Leave event is raised for the TextBox and GroupBox, and the Enter event is raised for the other GroupBox and TextBox.

注意事項

EnterGotFocus、 、LostFocus、、またはValidatedの各イベントハンドラー内からフォーカスを設定しないようにしてください。 Validating LeaveDo not attempt to set focus from within the Enter, GotFocus, Leave, LostFocus, Validating, or Validated event handlers. これにより、アプリケーションまたはオペレーティングシステムが応答を停止する可能性があります。Doing so can cause your application or the operating system to stop responding. 詳細については、 WM_KILLFOCUSのトピックを参照してください。For more information, see the WM_KILLFOCUS topic.

イベントの処理の詳細については、「処理とイベントの発生」を参照してください。For more information about handling events, see Handling and Raising Events.

適用対象

こちらもご覧ください