Class
Collection
Description
Used to store a set of related items in a larger structure. The concept of a Collection is similar to that of an array, except that each element in a Collection can be a different data type. A Collection can be thought of as an array of variants. Also, each element in a Collection can be named. Elements in a Collection can be referred to either by number or name.
Tip
This class is primarily for Visual Basic compatibility. The Dictionary class provides the same functionality but with greater speed.
Method descriptions
Collection.Add
Add(Value As Variant, [Key As String])
Adds Value as the last element of the Collection.
If Key is provided, it may be used to refer to the element using the Item property. Key defaults to the empty string.
The following code creates a Collection, populates it with both string and numeric values, and displays each element in TextFields or a Canvas control (The picture "lois" has been added to the project). Note that a Collection is much like a database record.
Var c As New Collection
c.Add(1, "ID")
c.Add("Lois Lane", "Name")
c.Add("Reporter", "JobTitle")
c.Add(85000, "Salary")
c.Add(lois, "Picture")
TextField1.Text = c.Item("ID")
TextField2.Text = c.Item(2) ' returns "Lois Lane"
TextField3.Text = c.Item("JobTitle")
TextField4.Text = c.Item("Salary")
Canvas1.Backdrop = c.Item("Picture")
Collection.Count
Count As Integer
The number of elements in the Collection. Returns an integer. Each element is a Value, Key pair.
The following code displays the value of Count in a TextField.
Var c As New Collection
c.Add(1, "ID")
c.Add("Lois Lane", "Name")
c.Add("Reporter", "JobTitle")
c.Add(85000, "Salary")
c.Add(lois, "Picture") ' lois is a Picture added to the project
TextField1.Text = c.Item("ID")
TextField2.Text = c.Item(2) ' returns "Lois Lane"
TextField3.Text = c.Item("JobTitle")
TextField4.Text = c.Item("Salary")
Canvas1.Backdrop = c.Item("Picture")
TextField5.Text = c.Count.ToString
Collection.Item
Item(index As Integer) As Variant
Refers to an element of a Collection by the value of its Key.
The following code displays the elements in the Collection using Item.
Var c As New Collection
c.Add(1, "ID")
c.Add("Lois Lane", "Name")
c.Add("Reporter", "JobTitle")
c.Add(85000, "Salary")
c.Add(lois, "Picture") ' lois is a Picture added to the project
TextField1.Text = c.Item("ID")
TextField2.Text = c.Item(2) ' returns "Lois Lane"
TextField3.Text = c.Item("JobTitle")
TextField4.Text = c.Item("Salary")
Canvas1.Backdrop = c.Item("Picture")
Collection.Key
Key(index As Integer) As Variant
Refers to the key for an element of a Collection. index is 1-based.
The following code fetches some elements in the Collection:
Var c As New Collection
c.Add(1, "ID")
c.Add("Lois Lane", "Name")
c.Add("Reporter", "JobTitle")
c.Add(85000, "Salary")
Var name As String = c.Item(2) ' returns "Lois Lane"
Var nameKey As String = c.Key(2) ' returns "Name"
Collection.Remove
Remove(index As Integer)
Removes the element of a Collection specified by the value of its Key.
This code removes the first element.
Var c As New Collection
.
.
c.Remove(1)
If you want to use the Item or Remove methods to refer to an item, use parentheses around the parameter passed to the method. This is because the compiler doesn't know which data type you are passing. For example, use
c.Remove("Name")
rather than
c.Remove "Name"
Notes
The Dictionary class provides all the functionality of the Collection class and offers several advantages: With the Collection class, the time taken to locate an item is a function of the number of items in the Collection because the search is sequential. A Dictionary uses a hash table, making the time (relatively) independent of the number of items. It is designed for high-speed lookups. Also, the key parameter in a Dictionary is a Variant, but is a String in the Collection class. Therefore, we recommend that you use the Dictionary class rather than the Collection class whenever possible.
Sample code
The following example creates a Collection, populates it with both string and numeric values, and displays each element in TextFields or a Canvas control (The picture "lois" has been added to the project). Note that a Collection is much like a database record.
Var c As New Collection
c.Add(1, "ID")
c.Add("Lois Lane", "Name")
c.Add("Reporter", "JobTitle")
c.Add(85000, "Salary")
c.Add(lois, "Picture") ' lois is a Picture added to the project
TextField1.Text = c.Item("ID")
TextField2.Text = c.Item(2) ' returns "Lois Lane"
TextField3.Text = c.Item("JobTitle")
TextField4.Text = c.Item("Salary")
Canvas1.Backdrop = c.Item("Picture")
If you want to use the Item or Remove methods to refer to an item, use parentheses around the parameter passed to the method. This is because the compiler doesn't know which data type you are passing. For example, use
c.Remove("Name")
rather than
c.Remove "Name"
Compatibility
Desktop, web and console projects on all supported operating systems.
See also
Object parent class; Dictionary, Variant classes; VarType function; Nil datatype