Tag

Tags represent a set of keywords that help label, categorize, and organize objects. Commonly used to signify the attributes of an object.

UsageCodeAccessibility
MathematicsHistoryScience
<sl-tag>Mathematics</sl-tag>
<sl-tag removable>History</sl-tag>
<sl-tag disabled removable>Science</sl-tag>

When to use

Categorization, Labeling, and Filtering

Use tags to categorize and label course content, enhancing organization, discoverability, and enabling efficient filtering of content on a page, within components, or through search functionalities. For instance, courses or lessons can be tagged with subjects such as "Mathematics," "Science," "History," or "Literature." This approach makes it easier for users to quickly find and access relevant materials.

User-Generated Tags

Enable users to create and manage their own custom labels, allowing for a personalized organization system. In a student dashboard, for example, users might tag their notes or assignments with custom labels like "Exam Prep," "Homework," "Group Project," or "To Review," facilitating better organization.

When not to use

Status Indicators

For tracking the status of tasks or items, such as "In Progress," "Completed," or "Pending," use a badge instead. Badges are specifically designed to convey status and can provide visual cues through colors, making them more effective for this purpose.

Anatomy tag

ItemNameDescriptionOptional
1ContainerThe container contains the label and close buttonno
2LabelThe label is a brief text that decribed the tagno
3Close buttonTo remove the tagyes

Anatomy tag list

ItemNameDescriptionOptional
1CounterDisplays the count of selected tags when not all tags are visible, with a maximum display of 99. If more than 99 tags are selected, it will be shown as "99+."yes
2List of tagsConsists of a collection of tagsno

Figma Options

With these options, you can tweak the appearance of the tag in Figma. They are available in the Design Panel so you can compose the tag to exactly fit the user experience need for the use case you are working on.

Tag

ItemOptionsDescription
Emphasissubtle boldIndicates the which emphasis the tag should have
State tagidle hover active disabledIndicates the state of the tag
State closeidle hover active disabledIndicates the state of the close button
Sizemd lgSize 'md' is the default size of the tag component
RemovablebooleanDisplays a close button
LabelvalueThe text of the label
Focus ringbooleanTo show the focus ring of the tag

Tag list

ItemOptionsDescription
Emphasissubtle boldIndicates the which emphasis the tag should have
Sizemd lgIndicates the size of the tag list
Items1 2 3 4 5 6Indicates how many tags are shown in the tag list
StackedbooleanIndicates if the tags are stacked, this will show a counter in front of the tag list
MathematicsGeographyPhysicsBiologyChemistryComputer ScienceEnglish
  <sl-tag-list stacked>
    <sl-tag removable>Mathematics</sl-tag>
    ...
    <sl-tag removable>English</sl-tag>
  </sl-tag-list>

Tag list API

Tag list component provides properties to define the experience in different use cases, and it is a kind of wrapper for multiple tags.

Properties

NameAttributeTypeDefaultDescription
emphasisemphasis'subtle' | 'bold' | undefinedThe emphasis of the tag-list and tags inside. Defaults to 'subtle'.
sizesize'md' | 'lg' | undefinedThe size of the tag-list (determines size of tags inside the tag-list). Defaults to `md`.
stackedstackedboolean | undefinedThis will hide tags that do not fit inside the available space when set. It will also
display a counter that indicates the number of hidden tags.

Slots

NameDescription
defaultThe place for tags.

Tag API

Tag has a range of properties to define the experience in different use cases.

Properties

NameAttributeTypeDefaultDescription
disableddisabledboolean | undefinedWhether the tag component is disabled, when set no interaction is possible.
emphasisemphasis'subtle' | 'bold' | undefinedThe emphasis of the tag; defaults to 'subtle'.
removableremovableboolean | undefinedWhether the tag component is removable.
sizesize'md' | 'lg' | undefinedThe size of the tag. Defaults to `md`.

Events

NameEvent typeDescription
sl-removeSlRemoveEventEmits when the tag is removed.

Slots

NameDescription
defaultThe tag label.

Keyboard interactions

The tag list component uses a roving tabindex. You can focus the first tag in the list by pressing the Tab key. After that, you can navigate through the tags using the left and right arrow keys. You can navigate back to the previous tag with left. The focus indicator loops, so when you are at the last option and press right it will focus on the first tag. In the stacked version of tag-list, when there are hidden tags, you can navigate only through visible tags with arrow keys. The first tag indicates how many hidden tags there are. Using a screen reader, it will announce how many hidden tags there are.

When you click on a tag inside a tag-list (as long as it is not disabled), the tag become the active spot for using the keyboard. This means you can start using keyboard navigation right from the tag you just clicked on.

When the tag is focused and is removable, it can be removed by pressing the Delete or Backspace key. This behavior is also announced by the screen reader.

WAI-ARIA

WAI-ARIA Roles, States, and Properties for a tag and tag-list component provide essential information to assistive technologies and screen readers.

Tag

AttributeValueDescriptionUser suppliedSpecifies whether the attribute is always set in the component (no) or it needs to be provided by the developer (yes)
role'listitem', 'button'Identifies the tag element as a listitem when it's used inside the sl-tag-list - this role is added automatically. Please provide a role button when the tag is interactive, is used to perform an action or is removable and not used inside sl-tag-list.no/yes
aria-descriptionstringDefines a string that describes the action that will be performed when the user interacts with the tag or the purpose/more information about the tag. aria-description is added automatically for the removable tag to describe the ability to use the keyboard to remove the tag.no
aria-labelledbystringUsed to label the tag that indicates the number of hidden tags, when the tag list overflows. It contains the id of the tooltip. The tooltip lists all the hidden tags.no

Tag list

AttributeValueDescriptionUser supplied
role'list'Identifies the tag-list as a list.no
aria-labelstringString that labels the tag list. Use this to label what the tag list indicates, such as the selected options in a combobox.yes
aria-labelledbystringCan be used to connect with a single header/element that describes the tag list.yes
Interactive example