PRB: ActiveControl Set to "Nothing" on Disabled Form
ID: Q173348
 
  | 
The information in this article applies to:
- 
Microsoft Visual Basic Learning, Professional, and Enterprise Editions for Windows, versions  5.0, 6.0
 
SYMPTOMS
In Microsoft Visual Basic version 4.0 for Windows, referencing the
ActiveControl property of a form that has been disabled returns the
control. In Visual Basic for Windows versions 5.0 and later, referencing
the ActiveControl property of a form that has been disabled causes run-time
error 91 "Object variable or With block variable not set" to be displayed.
CAUSE
In Visual Basic 5.0 and later, the value of the ActiveControl property of a
form is set to "Nothing" when the form is disabled.
RESOLUTION
The behavior is correct. This change in behavior may affect Visual Basic
4.0 applications that have been coded to the old behavior and then
converted to Visual Basic 5.0 or later. One workaround for this problem is
to store the value of the ActiveControl property in a variable before a
form is disabled. That variable can later be used to reference the control.
To prevent the run-time error from occurring, change the code to the
following:
   Public Form2LastControl As Control 'General Declarations of Form1
   Private Sub Command1_Click()
   Set Form2LastControl = Form2.ActiveControl
   Form2.Enabled = False
   End Sub
   Private Sub Command2_Click()
   MsgBox Form2LastControl.Text
   End Sub
   Private Sub Form_Load() 'Form Load Event of Form1
   Form2.Show vbModeless
   End Sub
   Private Sub Form_Load() 'Form Load Event of Form2
   Set Form1.Form2LastControl = Me.Controls(0)
   End Sub 
STATUS
This behavior is by design.
MORE INFORMATION
Steps to Reproduce Behavior
- Create a new Visual Basic Standard EXE project. Form1 is created by
   default.
 
- Add a form to the project (two forms are needed).
 
- Place two command buttons on Form1. For example:
      Name: Command1, Caption: Disable Form 2
      Name: Command2, Caption: Active Control 
 
- Add the following code to Form1:
      Private Sub Command1_Click()
      Form2.Enabled = False
      End Sub
      Private Sub Command2_Click()
      MsgBox Form2.ActiveControl.Text
      End Sub
      Private Sub Form_Load()
      Form2.Show vbModeless
      End Sub 
 
- Place a TextBox control on Form2.
 
- Run the project, and click on the "Active Control" command button.
 
- You should see a message box that says "Text1."
 
- Click on the command button labeled "Disable Form2."
 
- Click on the command button labeled "Active Control."
 
- Run-time error 91 "Object variable or With block variable not set" is
    displayed.
 
Additional query words: 
kbVBp kbdsd kbDSupport kbVBp500 kbVBp600 kbControl 
Keywords          : kbGrpVB 
Version           : 
Platform          : WINDOWS 
Issue type        : kbprb