Reference API Roblox

Engine API

Website

Related

Reference API Roblox

CollectionService

A service which manages object collections using assigned tags.

This class is not creatable. Instances of this class cannot be created with Instance.new.
This class is a service. It is a singleton that may be acquired with GetService.
Tags: [NotCreatable, Service]

Member index 13

HistoryMember
637AddTag(instance: Instance, tag: string): null
525GetAllTags(): Array
648GetCollection(class: string): Instances
462GetInstanceAddedSignal(tag: string): RBXScriptSignal
462GetInstanceRemovedSignal(tag: string): RBXScriptSignal
648GetTagged(tag: string): Instances
637GetTags(instance: Instance): Array
637HasTag(instance: Instance, tag: string): bool
637RemoveTag(instance: Instance, tag: string): null
553ItemAdded(instance: Instance)
553ItemRemoved(instance: Instance)
525TagAdded(tag: string)
525TagRemoved(tag: string)
inherited from Instance
553Archivable: bool
635Capabilities: SecurityCapabilities
553Name: string
553Parent: Instance
635Sandboxed: bool
616UniqueId: UniqueId
576AddTag(tag: string): null
573ClearAllChildren(): null
462Clone(): Instance
573Destroy(): null
486FindFirstAncestor(name: string): Instance
486FindFirstAncestorOfClass(className: string): Instance
486FindFirstAncestorWhichIsA(className: string): Instance
486FindFirstChild(name: string, recursive: bool = false): Instance
486FindFirstChildOfClass(className: string): Instance
486FindFirstChildWhichIsA(className: string, recursive: bool = false): Instance
486FindFirstDescendant(name: string): Instance
563GetActor(): Actor
486GetAttribute(attribute: string): Variant
462GetAttributeChangedSignal(attribute: string): RBXScriptSignal
631GetAttributes(): Dictionary
648GetChildren(): Instances
462GetDebugId(scopeLength: int = 4): string
486GetDescendants(): Array
486GetFullName(): string
641GetStyled(name: string): Variant
657GetStyledPropertyChangedSignal(property: string): RBXScriptSignal
576GetTags(): Array
576HasTag(tag: string): bool
486IsAncestorOf(descendant: Instance): bool
486IsDescendantOf(ancestor: Instance): bool
580IsPropertyModified(name: string): bool
573Remove(): null
576RemoveTag(tag: string): null
580ResetPropertyToDefault(name: string): null
573SetAttribute(attribute: string, value: Variant): null
462WaitForChild(childName: string, timeOut: double): Instance
648children(): Instances
553clone(): Instance
573destroy(): null
553findFirstChild(name: string, recursive: bool = false): Instance
648getChildren(): Instances
553isDescendantOf(ancestor: Instance): bool
573remove(): null
462AncestryChanged(child: Instance, parent: Instance)
462AttributeChanged(attribute: string)
462ChildAdded(child: Instance)
462ChildRemoved(child: Instance)
462DescendantAdded(descendant: Instance)
462DescendantRemoving(descendant: Instance)
500Destroying()
657StyledPropertiesChanged()
553childAdded(child: Instance)
inherited from Object
647ClassName: string
647className: string
647GetPropertyChangedSignal(property: string): RBXScriptSignal
647IsA(className: string): bool
650isA(className: string): bool
647Changed(property: string)

Description

CollectionService manages groups (collections) of instances with tags. Tags are sets of strings applied to objects that replicate from the server to the client. They are also serialized when places are saved.

The primary use of CollectionService is to register instances with specific tags that you can use to extend their behavior. If you find yourself adding the same script to many different objects, perhaps a script that uses CollectionService would be better.

Tags can be added or removed through this class' methods such as AddTag() or RemoveTag(). They can also be managed directly in Studio through the Tags section of an instance's properties, or through the built‑in Tag Editor tool.

Replication

When tags replicate, all tags on an object replicate at the same time. Therefore, if you set a tag on an object from the client then add/remove a different tag on the same object from the server, the client's local tags on the object are overwritten. In StreamingEnabled places, instances can be unloaded as they leave the client's streamed area. If such an instance re-enters the streamed area, properties and tags will be re-synchronized from the server. This can cause changes made by LocalScripts to be overwritten/removed.

History 43

Members 13

AddTag

Parameters (2)
instanceInstance
tagstring
Returns (1)
null

AddTag will apply a tag to an Instance, doing nothing if the tag is already applied to the instance. Successfully adding a tag will fire a signal created by CollectionService:GetInstanceAddedSignal() with the given tag.

Warnings

  • An instance's tags that were added client-side will be dropped if the server later adds or removes a tag on that instance because the server replicates all tags together and overwrites previous tags.

  • When tagging an instance, it is common that some resources are used to give the tag its functionality, for example event connections or tables. To prevent memory leaks, it's a good idea to clean these up (disconnect, set to nil, etc.) when no longer needed for a tag. Do this when calling CollectionService:RemoveTag(), calling Instance:Destroy() or in a function connected to a signal returned by CollectionService:GetInstanceRemovedSignal().

This function has a custom internal state. It may behave in a non-standard way.

History 4

Tags: [CustomLuaState]

GetAllTags

Parameters (0)
No parameters.
Returns (1)
Array

History 1

GetCollection

Parameters (1)
classstring
Returns (1)
Instances

This function returns all instances of a given class which are in the DataModel. Only works for Configuration, CustomEvent, CustomEventReceiver, Dialog, and VehicleSeat.

This function is deprecated. It exists only for backward compatibility, and should not be used for new work. GetTagged should be used instead.

History 7

Tags: [Deprecated]

GetInstanceAddedSignal

Parameters (1)
tagstring
Returns (1)
RBXScriptSignal

GetInstanceAdded is given a tag (a string) and returns a signal which fires under two conditions:

Subsequent calls to this method with the same tag return the same signal object. Consider also calling CollectionService:GetTagged() to get a list of objects that already have a tag (and thus won't fire the event if they already are in the DataModel).

See also CollectionService:GetInstanceRemovedSignal(), which returns an event that fires under similar conditions.

History 2

GetInstanceRemovedSignal

Parameters (1)
tagstring
Returns (1)
RBXScriptSignal

GetInstanceRemoved is given a tag (a string) and returns a signal which fires under two conditions:

Subsequent calls to this method with the same tag return the same signal object. The signal is useful for cleaning up resources used by objects that once had tags, such as disconnecting connections.

See also CollectionService:GetInstanceAddedSignal(), which returns an event that fires under similar conditions.

History 2

GetTagged

Parameters (1)
tagstring
Returns (1)
Instances

GetTagged returns an array of objects with a given tag which are descendants of the DataModel (game). Such tags have been added using CollectionService:AddTag(), and removing a tag using CollectionService:RemoveTag() will ensure this method does not return them. Although the name of this method is past-tense, this method only returns objects presently tagged with the given tag. It will not return objects that once had a tag but no longer have it.

If you want to detect all objects with a tag, both present and future, use this method to iterate over objects while also making a connection to a signal returned by CollectionService.GetInstanceAddedSignal.

This method does not guarantee any ordering of the returned objects. Additionally, it is possible that objects can have the given tag assigned to them, but not be a descendant of the DataModel, i.e. its parent is nil. This method will not return such objects.

History 4

GetTags

Parameters (1)
instanceInstance
Returns (1)
Array

GetTags is given an instance and returns an array of strings, which are the tags applied to the given object.

local CollectionService = game:GetService("CollectionService")
local object = workspace.Model
local tags = CollectionService:GetTags(object)
print("The object " .. object:GetFullName() .. " has tags: " .. table.concat(tags, ", "))

This method is useful when you want to do something with multiple tags at once on an object. However, it would be inefficient to use this method to check for the existence of a single tag. For this, use CollectionService:HasTag() to check for a single tag.

This function has a custom internal state. It may behave in a non-standard way.

History 4

Tags: [CustomLuaState]

HasTag

Parameters (2)
instanceInstance
tagstring
Returns (1)
bool

HasTag returns whether a given object has a tag.

By extension, any tags returned by a call to CollectionService:GetTags() on an object will return true when used with this method.

This function has a custom internal state. It may behave in a non-standard way.

History 4

Tags: [CustomLuaState]

ItemAdded

Parameters (1)
instanceInstance

This function fires when a Configuration, CustomEvent, CustomEventReceiver, Dialog, or VehicleSeat is added to the DataModel.

This event is deprecated. It exists only for backward compatibility, and should not be used for new work. GetInstanceAddedSignal should be used instead.

History 4

Tags: [Deprecated]

ItemRemoved

Parameters (1)
instanceInstance

This function fires when a Configuration, CustomEvent, CustomEventReceiver, Dialog, or VehicleSeat is removed from the DataModel.

This event is deprecated. It exists only for backward compatibility, and should not be used for new work. GetInstanceRemovedSignal should be used instead.

History 4

Tags: [Deprecated]

RemoveTag

Parameters (2)
instanceInstance
tagstring
Returns (1)
null

RemoveTag will remove a tag from an instance. This method will not throw an error if the object did not have the tag in the first place. Successfully removing a tag will fire a signal created by CollectionService:GetInstanceRemovedSignal() with the given tag.

When removing a tag, it is common that some resources are used to give the tag its functionality, e.g. event connections or tables. To prevent memory leaks, it is a good idea to clean these up (disconnect, set to nil, etc) when no longer needed for a tag.

This function has a custom internal state. It may behave in a non-standard way.

History 4

Tags: [CustomLuaState]

TagAdded

Parameters (1)
tagstring

This event fires when a tag is added to an object and the added tag is the only occurrence of that tag in the place.

History 1

TagRemoved

Parameters (1)
tagstring

This event fires when a tag is removed from an object and the removed tag is no longer used anywhere in the place.

History 1

Settings