Microsoft KB Archive/208777

= ACC2000: Report Auto List Members Shows Generic Control Object List =

Article ID: 208777

Article Last Modified on 6/24/2004

-

APPLIES TO


 * Microsoft Access 2000 Standard Edition

-



This article was previously published under Q208777



Moderate: Requires basic macro, coding, and interoperability skills.

This article applies to a Microsoft Access database (.mdb) and to a Microsoft Access project (.adp).



SYMPTOMS
The Auto List Members feature in Microsoft Access helps you type Visual Basic for Applications code by displaying a list of an object's properties and methods as you type.

However, when you type the name of a report control in the class module of a report, the Auto List Members box displays a generic list of methods and properties instead of those specific to that type of control. When you type the name of a form control in the class module of a form, the Auto List Members box displays a specific list of methods and properties for that type of control.



CAUSE
Report controls display a generic list of methods and properties because they do not support the same methods and properties as their counterparts on a form. For example, you cannot use the standard methods of a text box, label, or object frame control in a report the same way you can on a form because a report control does not trigger events.



RESOLUTION
If you want to see a specific list of methods and properties for a control on a report, you must explicitly declare the control object. For example, if your report has a text box control called Text0, then the following line of code displays a generic list of methods and properties in the Auto List Members box: Me!Text0. However, if you dimension a variable of type TextBox as in the following example, you see a specific list of text box methods and properties in the Auto List Members box:

Dim x as TextBox Set x = Me!Text0 x.



Steps to Reproduce Behavior
 Open the sample database Northwind.mdb. On the Tools menu, point to Macro, and then click Visual Basic Editor. In the Visual Basic Editor, on the Tools menu, click Options. On the Editor tab, click to select Auto List Members if it is not already selected. Click OK in the Options dialog box.</li> Open the Employees form in Design view.</li> On the View menu, click Code.</li>  Type the following portion of a procedure: Sub AutoMem Me!EmployeeId. Note that when you type the period (.) after EmployeeId, the Auto List Members box displays the methods and properties of a text box control object. The list contains AddColon, AfterUpdate, AllowAutoCorrect, and many others. </li> Close the Employees form without saving it.</li> Open the Catalog report in Design view.</li> On the View menu, click Code.</li>  Type the following portion of a procedure: Sub AutoMem Me!CategoryName. Note that when you type the period after CategoryName, the Auto List Members box displays a generic list of methods and properties for a control object. </li>  Retype the code in step 12 so that it looks as follows: Sub AutoMem Dim x as TextBox Set x = Me!CategoryName x. Note that when you type the period after the x, the Auto List Members box displays the same list of methods and properties that you see in step 8. </li> Close the Catalog report without saving it.</li></ol>

<div class="references_section">