跳转到内容

Select 选择器

何时使用

  • 弹出一个下拉菜单给用户选择操作,用于代替原生的选择器,或者需要一个更优雅的多选器时。
  • 当选项少时(少于 5 项),建议直接将选项平铺,使用 Radio 是更好的选择。
  • 如果你在寻找一个可输可选的输入框,那你可能需要 AutoComplete

代码演示

基本使用

loading

带搜索框

loading

自定义搜索

loading

多选

loading

三种大小

loading

自定义下拉选项

loading

带排序的搜索

loading

标签

loading

分组

loading

联动

loading

搜索框

loading

获得选项的文本

loading

自动分词

loading

搜索用户

loading

前后缀

loading

扩展菜单

loading

隐藏已选择选项

loading

形态变体

loading

自定义选择标签

loading

自定义选中 label

loading

响应式 maxTagCount

loading

大数据

loading

自定义状态

loading

弹出位置

loading

最大选中数量

loading

API

Select props

参数说明类型默认值版本
allowClear自定义清除按钮boolean | { clearIcon?: VNode }false5.8.0: 支持对象类型
autofocus默认获取焦点booleanfalse
classNames语义化结构 classRecord<SemanticDOM, string>-5.25.0
defaultActiveFirstOption是否默认高亮第一个选项booleantrue
disabled是否禁用booleanfalse
popupMatchSelectWidth下拉菜单和选择器同宽。默认将设置 min-width,当值小于选择框宽度时会被忽略。false 时会关闭虚拟滚动boolean | numbertrue5.5.0
popupRender自定义下拉框内容(originNode: VNode) => VNode-
fieldNames自定义节点 label、value、options、groupLabel 的字段object{ label: label, value: value, options: options, groupLabel: label }4.17.0(groupLabel 在 5.6.0 新增)
getPopupContainer菜单渲染父节点。默认渲染到 body 上,如果你遇到菜单滚动定位问题,试试修改为滚动的区域,并相对其定位。示例function(triggerNode)() => document.body
labelInValue是否把每个选项的 label 包装到 value 中,会把 Select 的 value 类型从 string 变为 { value: string, label: VNode } 的格式booleanfalse
listHeight设置弹窗滚动高度number256
loading加载中状态booleanfalse
maxCount指定可选中的最多 items 数量,仅在 modemultipletags 时生效number-5.13.0
maxTagCount最多显示多少个 tag,响应式模式会对性能产生损耗number | responsive-responsive: 4.10
maxTagPlaceholder隐藏 tag 时显示的内容VNode | function(omittedValues)-
maxTagTextLength最大显示的 tag 文本长度number-
menuItemSelectedIcon自定义多选时当前选中的条目图标VNode-
mode设置 Select 的模式为多选或标签multiple | tags-
notFoundContent当下拉列表为空时显示的内容VNodeNot Found
open(v-model)是否展开下拉菜单boolean-
optionLabelProp回填到选择框的 Option 的属性值,默认是 Option 的子元素。比如在子元素需要高亮效果时,此值可以设为 value示例stringchildren
options数据化配置选项内容,相比 jsx 定义会获得更好的渲染性能{ label, value }\[]-
optionRender自定义渲染下拉选项(option: FlattenOptionData<BaseOptionType> , info: { index: number }) => VNode-5.11.0
placeholder选择框默认文本string-
placement选择框弹出的位置bottomLeft bottomRight topLeft topRightbottomLeft
prefix自定义前缀VNode-5.22.0
removeIcon自定义的多选框清除图标VNode-
showSearch配置是否可搜索boolean | Object单选为 false,多选为 true
size选择框大小large | middle | smallmiddle
status设置校验状态'error' | 'warning'-4.19.0
suffixIcon自定义的选择框后缀图标。以防止图标被用于其他交互,替换的图标默认不会响应展开、收缩事件,可以通过添加 pointer-events: none 样式透传。VNode<DownOutlined />
styles语义化结构 styleRecord<SemanticDOM, CSSProperties>-5.25.0
tagRender自定义 tag 内容 render,仅在 modemultipletags 时生效(props) => VNode-
labelRender自定义当前选中的 label 内容 render (LabelInValueType的定义见 LabelInValueType(props: LabelInValueType) => VNode-5.15.0
tokenSeparators自动分词的分隔符,仅在 mode="tags" 时生效string[]-
value(v-model)指定当前选中的条目,多选时为一个数组。(value 数组引用未变化时,Select 不会更新)string | string[] |
number | number[] |
LabeledValue | LabeledValue[]
-
variant形态变体outlined | borderless | filled | underlinedoutlined5.13.0 | underlined: 5.24.0
virtual设置 false 时关闭虚拟滚动booleantrue4.1.0
onActive键盘和鼠标交互时触发function(value: string | number | LabeledValue)-
onBlur失去焦点时回调function-
onChange选中 option,或 input 的 value 变化时,调用此函数function(value, option:Option | Array<Option>)-
onClear清除内容时回调function-4.6.0
onDeselect取消选中时调用,参数为选中项的 value (或 key) 值,仅在 multipletags 模式下生效function(value: string | number | LabeledValue)-
onOpenChange展开下拉菜单的回调(open: boolean) => void-
onFocus获得焦点时回调(event: FocusEvent) => void-
onInputKeyDown按键按下时回调(event: KeyboardEvent) => void-
onPopupScroll下拉列表滚动时的回调(event: UIEvent) => void-
onSelect被选中时调用,参数为选中项的 value (或 key) 值function(value: string | number | LabeledValue, option: Option)-

注意,如果发现下拉菜单跟随页面滚动,或者需要在其他弹层中触发 Select,请尝试使用 getPopupContainer={triggerNode => triggerNode.parentElement} 将下拉弹层渲染节点固定在触发器的父元素中。

showSearch

PropertyDescriptionTypeDefaultVersion
autoClearSearchValue是否在选中项后清空搜索框,只在 modemultipletags 时有效booleantrue
filterOption是否根据输入项进行筛选。当其为一个函数时,会接收 inputValue option 两个参数,当 option 符合筛选条件时,应返回 true,反之则返回 false。示例boolean | function(inputValue, option)true
filterSort搜索时对筛选结果项的排序函数, 类似Array.sort里的 compareFunction(optionA: Option, optionB: Option, info: { searchValue: string }) => number-searchValue: 5.19.0
optionFilterProp搜索时过滤对应的 option 属性,如设置为 children 表示对内嵌内容进行搜索。若通过 options 属性配置选项内容,建议设置 optionFilterProp="label" 来对内容进行搜索。stringvalue
searchValue控制搜索文本string-
onSearch文本框值变化时回调function(value: string)-

Select Methods

名称说明版本
blur()取消焦点
focus()获取焦点

Option props

参数说明类型默认值版本
classOption 器类名string-
disabled是否禁用booleanfalse
title选项上的原生 title 提示string-
value默认根据此属性值进行筛选string | number-

OptGroup props

参数说明类型默认值版本
keyKeystring-
label组名VNode-
classOption 器类名string-
title选项上的原生 title 提示string-

基于 MIT 许可发布