Stats
75,594
reputation
147k
reached
260
answers
88
questions
Loading…
About
About Me
Me is a reserved name (you can't have a variable by that name) that refers to something that can only exist at run-time in a procedure's scope: the current object. Under the hood, when you make a member call to DoSomething against a Class1 object, the call goes essentially like this:
Set obj = New Class1
Class1.DoSomething obj
This means DoSomething looks like this in VBA:
Public Sub DoSomething()
End Sub
But VBA sees it like this:
Public Sub DoSomething(ByVal Me As Class1)
End Sub
That makes Me an implicit locally-scoped ByVal parameter of type Class1, and inside the DoSomething scope it holds a reference to whatever object the caller is currently using.
Moderator (retired) on Code Review Stack Exchange, 2015-2021
Microsoft MVP (Office Apps & Services), 2018-2022
Badges
View all badges
4
gold badges
-
ReversalSep 3, 2015
-
discussionJun 19, 2021
-
ElectorateJan 6, 2016
99
silver badges
-
LifejacketJun 18, 2019
-
TaxonomistAug 1, 2016
-
Strunk & WhiteNov 21, 2018
243
bronze badges
-
asking-questionsDec 17, 2017
-
scopeAug 16, 2016
-
specific-questionApr 18, 2016
Top tags
View all tags2,384
Score
309
Posts
89
Posts %
299
Score
22
Posts
6
Posts %
266
Score
29
Posts
8
Posts %
245
Score
36
Posts
10
Posts %
225
Score
60
Posts
17
Posts %
184
Score
30
Posts
9
Posts %


