Combobox follows the ARIA combobox pattern, with support for items and sections, and it provides slots for label and description elements within each item.
Custom localized announcements are included for option focusing, filtering, and selection using an ARIA live region to ensure announcements are clear and consistent.
A combobox consists of a label, an input which displays the current value, a list box popup, and an optional button used to toggle the list box popup open state.
Users can type within the input to filter the available options within the list box.
The list box popup may be opened by different interactions specified by the menuTrigger prop provided to Combobox, or by clicking or touching the button.
Combobox also supports optional description and error message elements, which can be used to provide more context about the field, and any validation messages. These are linked with the input via the aria-describedby attribute.
If the combobox does not have a visible label, an aria-label or aria-labelledby prop must be passed instead to identify it to assistive technology.
The filter function used to determine if a option should be included in the combobox list.
shouldFocusWrap
boolean
Whether keyboard navigation is circular.
defaultItems
Iterable<T>
false
The list of Combobox items (uncontrolled).
items
Iterable<T>
-
The list of Combobox items (controlled).
inputValue
string
The value of the Combobox input (controlled).
defaultInputValue
string
false
The default value of the Combobox input (uncontrolled).
allowsCustomValue
boolean
-
Whether the Combobox allows a non-item matching input value to be set.
menuTrigger
MenuTriggerAction
'input'
The interaction required to display the Combobox menu.
disabledKeys
Iterable<Key>
-
The item keys that are disabled. These items cannot be selected, focused, or otherwise interacted with.
selectedKey
React.Key | null
-
The currently selected key in the collection (controlled).
defaultSelectedKey
React.Key
-
The initial selected key in the collection (uncontrolled).
isDisabled
boolean
-
Whether the input is disabled.
isReadOnly
boolean
-
Whether the input can be selected but not changed by the user.
validationState
ValidationState
-
Whether the input should display its "valid" or "invalid" visual styling.
isRequired
boolean
-
Whether user input is required on the input before form submission.
Often paired with the necessityIndicator prop to add a visual indicator to the input.
autoFocus
boolean
-
Whether the element should receive focus on render.
Method that is called when the open state of the menu changes. Returns the new open state and the action that caused the opening of the menu.
onInputChange
(value: string) => void
-
Handler that is called when the ComboBox input value changes.
onSelectionChange
(key: React.Key) => any
-
Handler that is called when the selection changes.
onFocus
(e: FocusEvent<HTMLInputElement>) => void
-
Handler that is called when the element receives focus.
onBlur
(e: FocusEvent<HTMLInputElement>) => void
-
Handler that is called when the element loses focus.
onFocusChange
(isFocused: boolean) => void
-
Handler that is called when the element's focus status changes.
onKeyDown
(e: KeyboardEvent) => void
-
Handler that is called when a key is pressed.
onKeyUp
(e: KeyboardEvent) => void
-
Handler that is called when a key is released.
Layout
Name
Type
Default
Description
slot
string
-
A slot name for the component. Slots allow the component to receive props from a parent component.
Accessibility
Name
Type
Default
Description
id
string
-
The element's unique identifier. See MDN.
aria-label
string
-
Defines a string value that labels the current element.
aria-labelledby
string
-
Identifies the element (or elements) that labels the current element.
aria-describedby
string
-
Identifies the element (or elements) that describes the object.
aria-details
string
-
Identifies the element (or elements) that provide a detailed, extended description for the object.
Combobox.Label
A semantic HTML `<label>` that provides context for the combobox input element.
Name
Type
Default
Description
-
-
-
A `<Combobox.Label>` accepts all props supported by the `<label>` HTML element.
Combobox.Input
A semantic HTML `<input>` element that allows a user to enter plain text with a keyboard.
Name
Type
Default
Description
-
-
-
A <Combobox.Input> accepts all props supported by the <input> HTML element.
Combobox.Button
A semantic HTML `<button>` element that allows a user to perform an action. The `<Combobox.Button>` accepts its contents as `children`. Other props such as `onPress` and `isDisabled` will be set by the Combobox.
Name
Type
Default
Description
isDisabled
boolean
-
Whether the button is disabled.
autoFocus
boolean
-
Whether the element should receive focus on render.
type
'button' | 'submit' | 'reset'
'button'
The behavior of the button when used in an HTML form.
The inline style for the element. A function may be provided to compute the style based on component state.
Events
Name
Type
Default
Description
onPress
(e: PressEvent) => void
-
Handler that is called when the press is released over the target.
onPressStart
(e: PressEvent) => void
-
Handler that is called when a press interaction starts.
onPressChange
(isPressed: boolean) => void
-
Handler that is called when the press state changes.
onPressUp
(e: PressEvent) => void
-
Handler that is called when a press is released over the target, regardless of whether it started on the target or not.
onFocus
(e: FocusEvent<Target>) => void
-
Handler that is called when the element receives focus.
onBlur
(e: FocusEvent<Target>) => void
-
Handler that is called when the element loses focus.
onFocusChange
(isFocused: boolean) => void
-
Handler that is called when the element's focus status changes.
onKeyDown
(e: KeyboardEvent) => void
-
Handler that is called when a key is pressed.
onKeyUp
(e: KeyboardEvent) => void
-
Handler that is called when a key is released.
Layout
Name
Type
Default
Description
slot
string
-
A slot name for the component. Slots allow the component to receive props from a parent component.
Accessibility
Name
Type
Default
Description
id
string
-
The element's unique identifier. See MDN.
excludeFromTabOrder
boolean
-
Whether to exclude the element from the sequential tab order. If true, the element will not be focusable via the keyboard by tabbing. This should be avoided except in rare scenarios where an alternative means of accessing the element or its functionality via the keyboard is available.
aria-expanded
boolean | 'true' | 'false'
-
Indicates whether the element, or another grouping element it controls, is currently expanded or collapsed.
Indicates the availability and type of interactive popup element, such as menu or dialog, that can be triggered by an element.
aria-controls
string
-
Identifies the element (or elements) whose contents or presence are controlled by the current element.
aria-pressed
boolean | 'true' | 'false' | 'mixed'
-
Indicates the current "pressed" state of toggle buttons.
aria-label
string
-
Defines a string value that labels the current element.
aria-labelledby
string
-
Identifies the element (or elements) that labels the current element.
aria-describedby
string
-
Identifies the element (or elements) that describes the object.
aria-details
string
-
Identifies the element (or elements) that provide a detailed, extended description for the object.
Combobox.Popover
The `<Combobox.Popover>` is a container to hold the `<Listbox>` suggestions for a Combobox. By default, it has a placement of `bottom start` within a <Combobox>, but this and other positioning properties can be customized.
Name
Type
Default
Description
triggerRef
RefObject<Element>
-
The ref for the element which the popover positions itself with respect to.
When used within a trigger component such as DialogTrigger, MenuTrigger, Select, etc., this is set automatically. It is only required when used standalone.
placement
Placement
'bottom'
The placement of the element with respect to its anchor element.
containerPadding
number
12
The placement padding that should be applied between the element and its surrounding container.
offset
number
0
The additional offset applied along the main axis between the element and its anchor element.
crossOffset
number
0
The additional offset applied along the cross axis between the element and its anchor element.
shouldFlip
boolean
true
Whether the element should flip its orientation (e.g. top to bottom or left to right) when there is insufficient room for it to render completely.
isNonModal
boolean
-
Whether the popover is non-modal, i.e. elements outside the popover may be interacted with by assistive technologies.
Most popovers should not use this option as it may negatively impact the screen reader experience. Only use with components such as combobox, which are designed to handle this situation carefully.
isKeyboardDismissDisabled
boolean
-
Whether pressing the escape key to close the popover should be disabled.
Most popovers should not use this option. When set to true, an alternative way to close the popover with a keyboard must be provided.
arrowSize
number
0
Cross size of the overlay arrow in pixels.
boundaryElement
Element
document.body
Element that that serves as the positioning boundary.
scrollRef
RefObject<Element>
overlayRef
A ref for the scrollable region within the overlay.
shouldUpdatePosition
boolean
true
Whether the overlay should update its position automatically.
arrowBoundaryOffset
number
0
The minimum distance the arrow's edge should be from the edge of the overlay element.
The inline style for the element. A function may be provided to compute the style based on component state.
Events
Name
Type
Default
Description
onAction
(key: React.Key) => void
-
Handler that is called when a user performs an action on an item. The exact user event depends on the collection's selectionBehavior prop and the interaction modality.
onSelectionChange
(keys: Selection) => any
-
Handler that is called when the selection changes.
onFocus
(e: FocusEvent<Target>) => void
-
Handler that is called when the element receives focus.
onBlur
(e: FocusEvent<Target>) => void
-
Handler that is called when the element loses focus.
onFocusChange
(isFocused: boolean) => void
-
Handler that is called when the element's focus status changes.
Layout
Name
Type
Default
Description
slot
string
-
A slot name for the component. Slots allow the component to receive props from a parent component.
Accessibility
Name
Type
Default
Description
id
string
-
The element's unique identifier. See MDN.
aria-label
string
-
Defines a string value that labels the current element.
aria-labelledby
string
-
Identifies the element (or elements) that labels the current element.
aria-describedby
string
-
Identifies the element (or elements) that describes the object.
aria-details
string
-
Identifies the element (or elements) that provide a detailed, extended description for the object.
Combobox.Section
A `<Section>` defines the child items for a section within a `<Listbox>`. It may also contain an optional `<Header>` element. If there is no header, then an `aria-label` must be provided to identify the section to assistive technologies.
Name
Type
Default
Description
value
object
-
The object value that this section represents. When using dynamic collections, this is set automatically.
children
ReactNode | (item: object) => ReactElement
-
Static child items or a function to render children.
items
Iterable<T>
-
Item objects in the section.
className
string
0
The CSS className for the element.
style
CSSProperties
-
The inline style for the element.
Accessibility
Name
Type
Default
Description
id
React.Key
-
The unique id of the section.
aria-label
string
-
Defines a string value that labels the current element.
Combobox.Header
A `<Header>` defines the title for a `<Section>`.
Name
Type
Default
Description
-
-
-
Accepts all DOM attributes
Combobox.Item
An `<Item>` defines a single option within a `<Listbox>`. If the `children` are not plain text, then the `textValue` prop must also be set to a plain text representation, which will be used for autocomplete in the Combobox.
Name
Type
Default
Description
value
object
-
The object value that this section represents. When using dynamic collections, this is set automatically.
title
React.ReactNode
-
Rendered contents of the item if children contains child items.
textValue
string
-
A string representation of the item's contents, used for features like typeahead.
childItems
Iterable<T>
-
A list of child item objects. Used for dynamic collections.
hasChildItems
boolean
-
Whether this item has children, even if not loaded yet.