Show · Dropdown
Dropdown
A menu that pops down.
Demos
How to import
Basic Usage
- For the Trigger of the Dropdown within its children: By default, it is displayed on hover. You can modify it to values like
click
,custom
,contextMenu
, etc. through theprops.trigger
to specify different triggering methods. - Use
render
to specify the specific content of the dropdown box: UseDropdown.Menu
as the parent container, and useDropdown.Item
,Dropdown.Divider
, andDropdown.Title
in combination. Of course, in simple scenarios, you can also just combineDropdown.Menu
withDropdown.Item
, and the other elements are not mandatory. Dropdown.Item
can disable a certain option by settingdisabled
. By configuringtype
, text in different colors can be displayed. By settingicon
, icons can be quickly configured. For more complex custom structures, you can pass inReactNode
throughchildren
for custom rendering.
Nested Usage
Users can nested
Dropdown
, which is suitable for situations with multiple sublevel options.Popup Position
The position of support is the same. Tooltip, commonly used are: "bottom", "bottomLeft", "bottomRight".
Trigger Mode
The default is the move-in Trigger, which can be expanded by getting focus, clicking, or customizing the event trigger menu.
Trigger Event
Click on the menu item to trigger different mouse events, support
onClick
, onMouseEnter
, onMouseLeave
and onContextMenu
.Json Usage
Can use the menu attribute to configure the Dropdown content menu
API Reference
Dropdown
Properties | Instructions | Type | Default | Version |
---|---|---|---|---|
autoAdjustOverflow | Whether the pop-up layer automatically adjusts its direction when it is blocked | boolean | true | |
className | classname of the outer style of the pop-up layer | string | ||
closeOnEsc | Whether to close the panel by pressing the Esc key in the trigger or popup layer. It does not take effect when visible is under controlled | boolean | true | 2.13.0 |
children | Child elements wrapped by the drop layer | ReactNode | ||
clickToHide | Whether to close the drop-down layer automatically when clicking on the drop-down layer | boolean | 0.24.0 | |
contentClassName | Drop-down menu root element class name | string | ||
disableFocusListener | When trigger is hover , does not respond to the keyboard focus popup event, see details at issue#977 | boolean | true | 2.17.0 |
keepDOM | Whether to keep the internal component DOM from being destroyed when closing | boolean | false | 2.31.0 |
getPopupContainer | Specifies the parent DOM, and the bullet layer will be rendered to the DOM, you need to set 'position: relative` This will change the DOM tree position, but not the view's rendering position. | function():HTMLElement | () => document.body | |
margin | Popup layer calculates the size of the safe area when the current direction overflows, used in scenes covered by fixed elements, more detail refer to issue#549, same as Tooltip margin | object|number | 2.25.0 | |
mouseEnterDelay | After the mouse is moved into the Trigger, the display time is delayed, in milliseconds (only effective when the trigger is hover/focus) | number | 50 | |
mouseLeaveDelay | The time for the delay to disappear after the mouse moves out of the pop-up layer, in milliseconds (only effective when the trigger is hover/focus) | number | 50 | |
menu | Menu content config | Array<DropdownMenuItem> | [] | 1.12.0 |
position | The position of the pop-up menu, commonly used: 'bottom', 'bottomLeft', 'bottomRight', for more details, see Tooltip Position | string | 'bottom' | |
render | Content of pop-up layer,include Dropdown.Menu Dropdown.Item 、Dropdown.Title | ReactNode | ||
rePosKey | You can update the value of this item to manually trigger the repositioning of the pop-up layer | string | number | ||
spacing | The distance between the pop-up layer and the children element, in px | number | 4 | |
style | Pop-up layer inline style | object | ||
showTick | Whether to automatically display the checked tick on the left of the active Dropdown.Item item | boolean | false | 0.26.0 |
stopPropagation | Whether to prevent the click event on the pop-up layer from bubbling | boolean | false | 0.34.0 |
trigger | The act of triggering a drop-down, optional 'hover', 'focus', 'click', 'custom' | string | 'hover' | |
visible | Display the menu or not, need to be used with trigger custom | boolean | ||
zIndex | Pop-up layer z-index value | number | 1050 | |
onClickOutSide | Callback when the pop-up layer is in the display state and the non-Children, non-floating layer inner area is clicked (only valid when trigger is custom, click) | (e:event) => void | 2.1.0 | |
onEscKeyDown | Called when Esc key is pressed in trigger or popup layer | function(e:event) | 2.13.0 | |
onVisibleChange | Callback when the pop-up layer display state changes | function |
Dropdown.Menu
Properties | Instructions | Type | Default | Version |
---|---|---|---|---|
style | Drop-down menu style | object | 0.28.0 | |
className | Drop-down menu style class name | string | 0.28.0 | |
children | The child elements wrapped by the drop-down menu, usually Dropdown.Item or Dropdown.Title | ReactNode |
Dropdown.Item
Properties | Instructions | Type | Default | Version |
---|---|---|---|---|
active | Whether the current item is in the active state, there is a tick on the left when the active state is activated, the font is bold, and the color is deepened. When the showTick is false, even if the active is true, the tick will not be displayed | boolean | false | |
className | Style class name | string | ||
disabled | Do you disable the menu? | boolean | false | |
icon | Icon of DropdownItem, will be displayed on the left | ReactNode | 1.16.0 | |
style | Inline style | object | ||
type | Type, optional values: "primary","secondary", "tertiary", "warning", "danger" | string | "tertiary" | |
onClick | Click the trigger callback event | function | ||
onContextMenu | The callback event triggered by right click | function | 1.6.0 | |
onMouseEnter | A callback event triggered by MouseEnter | function | ||
onMouseLeave | The callback event triggered by Mouse Leave | function |
Dropdown.Title
Properties | Instructions | Type | Default |
---|---|---|---|
className | Style class name | string | "" |
style | Inline style | object | {} |
DropdownMenuItem
Properties | Instructions | Type |
---|---|---|
node | menu type: title ,item ,divider | string |
name | menu content | string |
Other Properties refer to Title、Item、Divider |
Accessibility
ARIA
- Dropdown.Menu
role
is set tomenu
,aria-orientatio
is set tovertical
- Dropdown.Item
role
is set tomenuitem
Keyboard and Focus
- Dropdown triggers can be focused, currently supports 3 triggering methods:
- When the trigger method is set to hover or focus: the Dropdown is opened when the mouse is hovering or focused. After the Dropdown is opened, the user can use the
Down Arrow
to move the focus to the Dropdown - When the trigger method is set to click: Use the
Enter
orSpace
key to open the Dropdown when clicking the trigger or focusing, and the focus will automatically focus on the first non-disabled item in the Dropdown
- When the trigger method is set to hover or focus: the Dropdown is opened when the mouse is hovering or focused. After the Dropdown is opened, the user can use the
- When the focus is on the menu item inside the Dropdown:
- Keyboard users can use the keyboard
Up Arrow
orDown Arrow
to switch between interactable elements - Use the
Enter
key or theSpace
key to activate the focused menu item, if the menu item is bound to onClick, the event will be fired
- Keyboard users can use the keyboard
- Keyboard users can close the Dropdown by pressing
Esc
, after which the focus returns to the trigger - Keyboard interaction does not yet fully support nested scenes
Content Guidelines
- The content of the options in the drop-down box needs to be expressed accurately and contain information to make it easier for users to choose among the options when browsing
- Use statement-like capitalization and write options concisely and clearly
- In the case of an action option, use a verb or verb phrase to describe the action that will occur when the user selects the option. For example, "Move", "Log time", or "Hide labels"
- do not use prepositions
✅ Recommended usage | ❌ Deprecated usage |
---|---|
Design Tokens
FAQ
- Why does the Dropdown layer accidentally wrap when the width is not enough near the screen border?After Chromium 104, the wrapping rendering strategy when the width of the screen border text is not enough has changed. For details, see issue #1022, the semi-side has been This problem was fixed in v2.17.0.