Properties
These are the quantifiable characteristics of an object.
You can find out whether an exception will be generated by looking in the object model documentation.
Property values can be Numerical, String or Boolean and they may be specific or apply to several objects.
They can be obtained or set by assignment statements.
You can easily use the NOT operator to toggle properties on or off. (eg ActiveWindow.DisplayAlerts = NOT ActiveWindow.DisplayAlerts).
Declarations
Also known as property procedures.
Property Get - used to retrieve a property of a class. Get the value of scalar of object property.
Lets you return a property value or property reference
Take action before retrieving
Return a calculated value
Property Let - used to assign the value to a property of a class. Set the value of scalar property.
Lets you define a new property value
Take action after setting
Perform data validation
Property Set - used to assign an object to a property of a class. Set a reference for object property.
Lets you define a new property reference
Property - Collection
Private field_colValue As Collection
Property Get Property_Name() As Collection
Set Property_Name = field_colValue
End Property
' You would use Set because Collection is a reference data type
Property Set Property_Name(colData As Collection)
Set field_colValue = colData
End Property
Property - Object
Private field_oValue As Object
Property Get Property_Name() As Object
Set Property_Name = field_oValue
End Property
' You would use Set because Object is a reference data type
Property Set Property_Name(oData As Object)
Set field_oValue = oData
End Property
Property - Date
Private field_dtValue As Date
Property Get Property_Name() As Date
Property_Name = field_dtValue
End Property
' You would use Let because Date is a value data type
Property Let Property_Name(dtData As Date)
field_dtValue = dtData
End Property
Property - String
Private field_sValue As String
Property Get PropertyName() As String
PropertyName = field_sValue
End Property
' You would use Let because String is a value data type
Property Let PropertyName(sData As String)
field_sValue = sData
End Property
Property - Variant
Private field_vValue As Variant
Property Get Property_Name() As Variant
If IsObject(field_vValue) Then
Set Property_Name = field_vValue
Else
Property_Name = field_vValue
End If
End Property
' You could use either Let or Set
Property Let Property_Name(vData As Variant)
field_vValue = rData
End Property
Property Set Property_Name(vData As Variant)
Set field_vValue = vData
End Property
Important
If you are using an Object data type then you must use Set instead of Let.
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext