Skip to content

DropdownMenu

What component has

Keyboard support

Keyboard support
KeyFunction
TabMoves focus to the next focusable element.
Shift + TabMoves focus to the previous focusable element.
Space, Enter, Up Arrow, Down ArrowWhen focus is on the trigger, opens the dropdown.
Up Arrow, Down ArrowMoves selection between the list options in the dropdown. If selection is on the last/first option, moves selection to the first/last option respectively.
Right ArrowMoves selection to the submenu or inline actions.
Left ArrowMoves selection to the parent menu item.
Space, EnterSelects the option and closes the dropdown. Or, if the option has a submenu, moves selection to the submenu.
EscCloses the menu.

When dropdown is closed, the focus stays on the trigger.

Roles & attributes

The following list describes roles and attributes that component already has.

Component / elementRole / AttributeUsage
DropdownMenu.Triggerrole="button"Tells the screen reader the element is a button.
aria-haspopup="true"Indicates that the element triggers a dialog.
aria-expanded="true/false"Set to true when dialog is visible. Indicates that the dialog is open.
aria-controls="IDREF"Indicates which element this Trigger opens.
DropdownMenu.MenumenuThe menu role is a type of composite widget that offers a list of choices to the user.
aria-labelledby="IDREF"Identifies the title for the menu.
DropdownMenu.Popperrole="dialog"Only if DropdownMenu.Popper is used explicitly. Identifies the popper as a dialog.
DropdownMenu.Item, DropdownMenu.Item.Contentrole="menuitem"Indicates that the element is a menu item. This is the default menu item role.
role="menuitemcheckbox"Only if the menu has both selectable and multiselect properties. Indicates that the element is a menu item that can be checked and unchecked.
role="menuitemradio"Only if the menu has the selectable property. Indicates that the element is a menu item that can be checked and unchecked within a set, where only one item can be checked at a time.
aria-describedby="IDREF"Gives the item an accessible description by referring to the Item.Hint, the tooltip, or both, describing the primary message or purpose of the item.
DropdownMenu.Item.Hintaria-hidden="true"Hides element from assistive technologies.
DropdownMenu.Item.Contentaria-haspopup="dialog"Indicates that the element triggers a dialog.
aria-expanded="true/false"Set to true when dialog is visible. Indicates that the dialog is open.
DropdownMenu.Grouprole="group"Identifies a set of user interface objects that's not intended to be included in a page summary or table of contents by assistive technologies.
aria-labeledby="IDREF"Identifies the title for the content group.

Considerations for developers

Only use DropdownMenu.Popper explicitly if it must have additional elements beside the menu, as in the example with a Notice. In that case the popper will be presented as a dialog, which hints to the screen reader user to use the Tab key to navigate between the menu and other elements.

If your DropdownMenu is a list of options without additional features, use it with DropdownMenu.Menu, as in the basic example. This will let the screen reader user know that Up and Down keys are enough to navigate within the control.

Roles and attributes

The following list will help you to keep in mind the necessary roles and attributes to make our components fully accessible in the particular cases in your interfaces.

Roles and attributes
ComponentAttributeUsage
DropdownMenu.Popperaria-label or aria-labelledbyOnly if DropdownMenu.Popper is used explicitly. Defines an accessible name for the popper.

Other recommendations

For more accessibility recommendations, refer to the common Accessibility guide.

Automated screen reader testing

Intergalactic v15.29.0, React v18.2.0, Playwright v1.25.1, Guidepup v0.13.1, MacOS Monterey 12.

Running screen reader against this file.

1. Screen reader presses the "Tab" button.
2. Screen reader says "Click me menu pop up button".
3. Screen reader presses the "Control+Option+Space" button.
4. Screen reader presses the "Tab" button.
5. Screen reader says "Click me submenu 4 items group".
6. Screen reader goes to the next element.
7. Screen reader says "Click me submenu 4 items group menu Click me 4 items".
8. Screen reader goes into the active element.
9. Screen reader goes to the next element.
10. Screen reader says "Item 1 menu item".
11. Screen reader goes to the next element.
12. Screen reader says "Item 2 menu item".
13. Screen reader presses the "Escape" button.
14. Screen reader says "Click me group".
15. Screen reader goes to the next element.
16. Screen reader says "Click me menu pop up button".

Last updated:

Released under the MIT License.

Released under the MIT License.