---
title: Select - 选择器
order: 9
path: /select
nav:
  order: 1
  title: 桌面组件
  path: /design
group:
  order: 3
  title: 数据录入
  path: /dataInput
---

用于收纳大量选项的信息录入类组件。

## 单选选择器

提供选择器，选取后只展示单个内容。

<code src='./demos/single.tsx' height="400px" >

## 多选选择器

提供多选的选择器，通过标签展示多选内容。

<code src='./demos/multiple.tsx' height='400px'>

## 分组选择器

对信息进行分组的选择器，能够直观呈现方便用户辨识。在有层级关系，但选项内容较少的场景下使用。

<code src='./demos/optgroup.tsx' height='400px' >

## 不同状态的选择器

提供 普通状态、禁用状态、加载状态 三种状态的选择器。

<code src='./demos/state.tsx' height='400px'>

## 不同尺寸的选择器

提供大、中（默认）、小三种不同尺寸的的选择器。

<code src='./demos/size.tsx' height='400px' >

## 可过滤的选择器

输入过滤已选项。在有特定诉求的业务场景时使用。

<code src='./demos/filter.tsx' height='400px'>

## 远程搜索选择器

可根据需求定制选择器内容。在有复杂逻辑或有特定诉求的业务场景时使用。

<code src='./demos/search.tsx' height='400px'>

## 可创建新条目的选择器

允许用户创建新条目

<code src='./demos/searchAdd.tsx' height='400px'>

## 文字选择器/无边框的选择器

通过文字按钮触发的选择器，用于修改内容。通常在空间受限、并且需要轻量化选择的场景使用。

<code src='./demos/borderless.tsx' height='400px'>

## 可折叠选项

多选情况下，超出该数值的选中项折叠。

<code src='./demos/maxcount.tsx' height='400px'>

## 自定义下拉框宽度选择器

自定义下拉样式的选择器，在需要自定义下拉样式时使用。

<code src='./demos/dropdownMatchSelectWidth.tsx' height='400px'>

### Select props

| 参数                     | 说明                                                                                                                                                                        | 类型                                                                              | 默认值                                                 | 版本             |
| ------------------------ | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------- | ------------------------------------------------------ | ---------------- |
| allowClear               | 支持清除                                                                                                                                                                    | boolean                                                                           | false                                                  |                  |
| autoClearSearchValue     | 是否在选中项后清空搜索框，只在 `mode` 为 `multiple` 或 `tags` 时有效                                                                                                        | boolean                                                                           | true                                                   |                  |
| autoFocus                | 默认获取焦点                                                                                                                                                                | boolean                                                                           | false                                                  |                  |
| bordered                 | 是否有边框                                                                                                                                                                  | boolean                                                                           | true                                                   |                  |
| clearIcon                | 自定义的多选框清空图标                                                                                                                                                      | ReactNode                                                                         | -                                                      |                  |
| defaultActiveFirstOption | 是否默认高亮第一个选项                                                                                                                                                      | boolean                                                                           | true                                                   |                  |
| defaultOpen              | 是否默认展开下拉菜单                                                                                                                                                        | boolean                                                                           | -                                                      |                  |
| defaultValue             | 指定默认选中的条目                                                                                                                                                          | string \| string\[]<br />number \| number\[]<br />LabeledValue \| LabeledValue\[] | -                                                      |                  |
| disabled                 | 是否禁用                                                                                                                                                                    | boolean                                                                           | false                                                  |                  |
| dropdownClassName        | 下拉菜单的 className 属性                                                                                                                                                   | string                                                                            | -                                                      |                  |
| dropdownMatchSelectWidth | 下拉菜单和选择器同宽。默认将设置 `min-width`，当值小于选择框宽度时会被忽略。false 时会关闭虚拟滚动                                                                          | boolean \| number                                                                 | true                                                   |                  |
| dropdownRender           | 自定义下拉框内容                                                                                                                                                            | (originNode: ReactNode) => ReactNode                                              | -                                                      |                  |
| dropdownStyle            | 下拉菜单的 style 属性                                                                                                                                                       | CSSProperties                                                                     | -                                                      |                  |
| fieldNames               | 自定义节点 label、value、options 的字段                                                                                                                                     | object                                                                            | { label: `label`, value: `value`, options: `options` } | 4.17.0           |
| filterOption             | 是否根据输入项进行筛选。当其为一个函数时，会接收 `inputValue` `option` 两个参数，当 `option` 符合筛选条件时，应返回 true，反之则返回 false                                  | boolean \| function(inputValue, option)                                           | true                                                   |                  |
| filterSort               | 搜索时对筛选结果项的排序函数, 类似[Array.sort](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/sort)里的 compareFunction             | (optionA: Option, optionB: Option) => number                                      | -                                                      | 4.9.0            |
| getPopupContainer        | 菜单渲染父节点。默认渲染到 body 上，如果你遇到菜单滚动定位问题，试试修改为滚动的区域，并相对其定位。[示例](https://codesandbox.io/s/4j168r7jw0)                             | function(triggerNode)                                                             | () => document.body                                    |                  |
| labelInValue             | 是否把每个选项的 label 包装到 value 中，会把 Select 的 value 类型从 `string` 变为 { value: string, label: ReactNode } 的格式                                                | boolean                                                                           | false                                                  |                  |
| listHeight               | 设置弹窗滚动高度                                                                                                                                                            | number                                                                            | 256                                                    |                  |
| loading                  | 加载中状态                                                                                                                                                                  | boolean                                                                           | false                                                  |                  |
| maxTagCount              | 最多显示多少个 tag，响应式模式会对性能产生损耗                                                                                                                              | number \| `responsive`                                                            | -                                                      | responsive: 4.10 |
| maxTagPlaceholder        | 隐藏 tag 时显示的内容                                                                                                                                                       | ReactNode \| function(omittedValues)                                              | -                                                      |                  |
| maxTagTextLength         | 最大显示的 tag 文本长度                                                                                                                                                     | number                                                                            | -                                                      |                  |
| menuItemSelectedIcon     | 自定义多选时当前选中的条目图标                                                                                                                                              | ReactNode                                                                         | -                                                      |                  |
| mode                     | 设置 Select 的模式为多选或标签                                                                                                                                              | `multiple` \| `tags`                                                              | -                                                      |                  |
| notFoundContent          | 当下拉列表为空时显示的内容                                                                                                                                                  | ReactNode                                                                         | `Not Found`                                            |                  |
| open                     | 是否展开下拉菜单                                                                                                                                                            | boolean                                                                           | -                                                      |                  |
| optionFilterProp         | 搜索时过滤对应的 `option` 属性，如设置为 `children` 表示对内嵌内容进行搜索。若通过 `options` 属性配置选项内容，建议设置 `optionFilterProp="label"` 来对内容进行搜索。       | string                                                                            | `value`                                                |                  |
| optionLabelProp          | 回填到选择框的 Option 的属性值，默认是 Option 的子元素。比如在子元素需要高亮效果时，此值可以设为 `value`。[示例](https://codesandbox.io/s/antd-reproduction-template-tk678) | string                                                                            | `children`                                             |                  |
| options                  | 数据化配置选项内容，相比 jsx 定义会获得更好的渲染性能                                                                                                                       | { label, value }\[]                                                               | -                                                      |                  |
| placeholder              | 选择框默认文本                                                                                                                                                              | string                                                                            | -                                                      |                  |
| placement                | 选择框弹出的位置                                                                                                                                                            | `bottomLeft` `bottomRight` `topLeft` `topRight`                                   | bottomLeft                                             |                  |
| removeIcon               | 自定义的多选框清除图标                                                                                                                                                      | ReactNode                                                                         | -                                                      |                  |
| searchValue              | 控制搜索文本                                                                                                                                                                | string                                                                            | -                                                      |                  |
| showArrow                | 是否显示下拉小箭头                                                                                                                                                          | boolean                                                                           | 单选为 true，多选为 false                              |                  |
| showSearch               | 使单选模式可搜索                                                                                                                                                            | boolean                                                                           | false                                                  |                  |
| size                     | 选择框大小                                                                                                                                                                  | `large` \| `middle` \| `small`                                                    | `middle`                                               |                  |
| status                   | 设置校验状态                                                                                                                                                                | 'error' \| 'warning'                                                              | -                                                      | 4.19.0           |
| suffixIcon               | 自定义的选择框后缀图标                                                                                                                                                      | ReactNode                                                                         | -                                                      |                  |
| tagRender                | 自定义 tag 内容 render，仅在 `mode` 为 `multiple` 或 `tags` 时生效                                                                                                          | (props) => ReactNode                                                              | -                                                      |                  |
| tokenSeparators          | 自动分词的分隔符，仅在 `mode="tags"` 时生效                                                                                                                                 | string\[]                                                                         | -                                                      |                  |
| value                    | 指定当前选中的条目，多选时为一个数组。（value 数组引用未变化时，Select 不会更新）                                                                                           | string \| string\[]<br />number \| number\[]<br />LabeledValue \| LabeledValue\[] | -                                                      |                  |
| virtual                  | 设置 false 时关闭虚拟滚动                                                                                                                                                   | boolean                                                                           | true                                                   | 4.1.0            |
| onBlur                   | 失去焦点时回调                                                                                                                                                              | function                                                                          | -                                                      |                  |
| onChange                 | 选中 option，或 input 的 value 变化时，调用此函数                                                                                                                           | function(value, option:Option \| Array&lt;Option>)                                | -                                                      |                  |
| onClear                  | 清除内容时回调                                                                                                                                                              | function                                                                          | -                                                      | 4.6.0            |
| onDeselect               | 取消选中时调用，参数为选中项的 value (或 key) 值，仅在 `multiple` 或 `tags` 模式下生效                                                                                      | function(string \| number \| LabeledValue)                                        | -                                                      |                  |
| onDropdownVisibleChange  | 展开下拉菜单的回调                                                                                                                                                          | function(open)                                                                    | -                                                      |                  |
| onFocus                  | 获得焦点时回调                                                                                                                                                              | function                                                                          | -                                                      |                  |
| onInputKeyDown           | 按键按下时回调                                                                                                                                                              | function                                                                          | -                                                      |                  |
| onMouseEnter             | 鼠标移入时回调                                                                                                                                                              | function                                                                          | -                                                      |                  |
| onMouseLeave             | 鼠标移出时回调                                                                                                                                                              | function                                                                          | -                                                      |                  |
| onPopupScroll            | 下拉列表滚动时的回调                                                                                                                                                        | function                                                                          | -                                                      |                  |
| onSearch                 | 文本框值变化时回调                                                                                                                                                          | function(value: string)                                                           | -                                                      |                  |
| onSelect                 | 被选中时调用，参数为选中项的 value (或 key) 值                                                                                                                              | function(string \| number \| LabeledValue, option: Option)                        | -                                                      |                  |

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

### Select Methods

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

### Option props

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

### OptGroup props

| 参数  | 说明 | 类型                    | 默认值 | 版本 |
| ----- | ---- | ----------------------- | ------ | ---- |
| key   | Key  | string                  | -      |      |
| label | 组名 | string \| React.Element | -      |      |

## FAQ

### `tag` 模式下为何搜索有时会出现两个相同选项？

这一般是 `options` 中的 `label` 和 `value` 不同导致的，你可以通过 `optionFilterProp="label"` 将过滤设置为展示值以避免这种情况。

### 点击 `dropdownRender` 里的内容浮层关闭怎么办？

自定义内容点击时会关闭浮层，如果不喜欢关闭，可以添加 `onMouseDown={e => e.preventDefault()}` 进行阻止（更多详情见 [#13448](https://github.com/ant-design/ant-design/issues/13448)）。

### 自定义 Option 样式导致滚动异常怎么办？

这是由于虚拟滚动默认选项高度为 `32px`，如果你的选项高度小于该值则需要通过 `listItemHeight` 属性调整，而 `listHeight` 用于设置滚动容器高度：

注意：`listItemHeight` 和 `listHeight` 为内部属性，如无必要，请勿修改该值。

### 为何无障碍测试会报缺失 `aria-` 属性？

Select 无障碍辅助元素仅在弹窗展开时创建，因而当你在进行无障碍检测时请先打开下拉后再进行测试。对于 `aria-label` 与 `aria-labelledby` 属性缺失警告，请自行为 Select 组件添加相应无障碍属性。
