Control.Leave イベント

定義

入力フォーカスがコントロールを離れると発生します。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
   
   
    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
End Class

注釈

キーボード (タブ、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

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

注意

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

注意事項

EnterGotFocusLeaveLostFocusValidating、または Validated のイベントハンドラー内からフォーカスを設定しないようにしてください。Do 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.

適用対象

こちらもご覧ください