Cascader

Cascade selection box.
Importimport{ Cascader }from"antd";

When To Use

  • When you need to select from a set of associated data set. Such as province/city/district, company level, things classification.
  • When selecting from a large data set, with multi-stage classifications separated for easy selection.
  • Chooses cascade items in one float layer for better user experience.

Examples

Please select

Cascade selection box for selecting province/city/district.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
Unselect Change city

Separate trigger button and result.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code

Disable option by specifying the disabled property in options.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code

Select multiple options. Disable the checkbox by adding the disableCheckbox property and selecting a specific item. The style of the disable can be modified by the className.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code






Cascade selection box of different sizes.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
Please select

Custom field names.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
Please select

Customize the dropdown menu via dropdownRender.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
Please select
Please select
Please select
Please select

Variants of Cascader, there are four variants: outlined filled borderless and underlined.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
5.13.0
No data
No data

Used for inline view case.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
>= 5.10.0
Zhejiang / Hangzhou / West Lake

Specifies default value by an array.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code

Hover to expand sub menu, click to select option.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code

Allows the selection of only parent options.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code


Shows a selected item in a box using showCheckedStrategy.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
Zhejiang / Hangzhou / West Lake (752100)

For instance, add an external link after the selected value.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code

Load options lazily with loadData.

Note: loadData cannot work with showSearch.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
Please select


Please select


Please select


Please select


Please select

Use prefix to customize the prefix content, use suffixIcon to customize the selection box suffix icon, and use expandIcon to customize the current item expand icon.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
5.22.0


Please select

You can manually specify the position of the popup via placement.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code
Error
Warning multiple

Add status to Cascader with status, which could be error or warning.

CodeSandbox Icon
codepen icon
External Link Icon
expand codeexpand code

API

Common props ref:Common props

<Cascader options={options} onChange={onChange} />
PropertyDescriptionTypeDefaultVersion
allowClearShow clear buttonboolean | { clearIcon?: ReactNode }true5.8.0: Support object type
autoClearSearchValueWhether the current search will be cleared on selecting an item. Only applies when multiple is truebooleantrue5.9.0
autoFocusIf get focus when component mountedbooleanfalse
changeOnSelectChange value on each selection if set to true, see above demo for detailsbooleanfalse
classNameThe additional css classstring-
defaultValueInitial selected valuestring[] | number[][]
disabledWhether disabled selectbooleanfalse
displayRenderThe render function of displaying selected options(label, selectedOptions) => ReactNodelabel => label.join(/)multiple: 4.18.0
tagRenderCustom render function for tags in multiple mode(label: string, onClose: function, value: string) => ReactNode-
popupClassNameThe additional className of popup overlaystring-4.23.0
dropdownRenderCustomize dropdown content(menus: ReactNode) => ReactNode-4.4.0
expandIconCustomize the current item expand iconReactNode-4.4.0
expandTriggerexpand current item when click or hover, one of click hoverstringclick
fieldNamesCustom field name for label and value and childrenobject{ label: label, value: value, children: children }
getPopupContainerParent Node which the selector should be rendered to. Default to body. When position issues happen, try to modify it into scrollable content and position it relative. examplefunction(triggerNode)() => document.body
loadDataTo load option lazily, and it cannot work with showSearch(selectedOptions) => void-
maxTagCountMax tag count to show. responsive will cost render performancenumber | responsive-4.17.0
maxTagPlaceholderPlaceholder for not showing tagsReactNode | function(omittedValues)-4.17.0
maxTagTextLengthMax tag text length to shownumber-4.17.0
notFoundContentSpecify content to show when no result matchesReactNodeNot Found
openSet visible of cascader popupboolean-4.17.0
optionsThe data options of cascadeOption[]-
placeholderThe input placeholderstring-
placementUse preset popup align config from builtinPlacementsbottomLeft bottomRight topLeft topRightbottomLeft4.17.0
prefixThe custom prefixReactNode-5.22.0
showSearchWhether show search input in single modeboolean | Objectfalse
sizeThe input sizelarge | middle | small-
statusSet validation status'error' | 'warning'-4.19.0
styleThe additional styleCSSProperties-
suffixIconThe custom suffix iconReactNode-
valueThe selected valuestring[] | number[]-
variantVariants of selectoroutlined | borderless | filled | underlinedoutlined5.13.0 | underlined: 5.24.0
onChangeCallback when finishing cascader select(value, selectedOptions) => void-
onDropdownVisibleChangeCallback when popup shown or hidden(value) => void-4.17.0
multipleSupport multiple or notboolean-4.17.0
removeIconThe custom remove iconReactNode-
showCheckedStrategyThe way show selected item in box. ** SHOW_CHILD: ** just show child treeNode. Cascader.SHOW_PARENT: just show parent treeNode (when all child treeNode under the parent treeNode are checked)Cascader.SHOW_PARENT | Cascader.SHOW_CHILDCascader.SHOW_PARENT4.20.0
searchValueSet search value, Need work with showSearchstring-4.17.0
onSearchThe callback function triggered when input changed(search: string) => void-4.17.0
dropdownMenuColumnStyleThe style of the drop-down menu columnCSSProperties-
loadingIconThe appearance of lazy loading (now is useless)ReactNode-
optionRenderCustomize the rendering dropdown options(option: Option) => React.ReactNode-5.16.0

showSearch

PropertyDescriptionTypeDefaultVersion
filterThe function will receive two arguments, inputValue and option, if the function returns true, the option will be included in the filtered set; Otherwise, it will be excludedfunction(inputValue, path): boolean-
limitSet the count of filtered itemsnumber | false50
matchInputWidthWhether the width of list matches input, (how it looks)booleantrue
renderUsed to render filtered optionsfunction(inputValue, path): ReactNode-
sortUsed to sort filtered optionsfunction(a, b, inputValue)-

Option

interface Option {
value: string | number;
label?: React.ReactNode;
disabled?: boolean;
children?: Option[];
// Determines if this is a leaf node(effective when `loadData` is specified).
// `false` will force trade TreeNode as a parent node.
// Show expand icon even if the current node has no children.
isLeaf?: boolean;
}

Methods

NameDescriptionVersion
blur()Remove focus
focus()Get focus

Design Token

Component TokenHow to use?

Token NameDescriptionTypeDefault Value
controlItemWidthWidth of itemstring | number111
controlWidthWidth of Cascaderstring | number184
dropdownHeightHeight of dropdownstring | number180
menuPaddingPadding of menu item (single column)undefined | Padding<string | number>4
optionPaddingPadding of menu itemundefined | Padding<string | number>5px 12px
optionSelectedBgBackground color of selected itemstring#e6f4ff
optionSelectedColorText color when option is selectedstringrgba(0,0,0,0.88)
optionSelectedFontWeightFont weight of selected itemundefined | FontWeight600

Global TokenHow to use?