2016-07-25 17:46:45 +08:00
---
category: Components
2016-11-09 14:43:32 +08:00
type: Data Entry
2017-02-20 00:09:07 +08:00
cols: 2
2016-09-08 16:53:50 +08:00
title: AutoComplete
2016-07-25 17:46:45 +08:00
---
Autocomplete function of input field.
2016-09-10 13:43:30 +08:00
## When To Use
2016-07-25 17:46:45 +08:00
2016-11-29 17:13:24 +08:00
When there is a need for autocomplete functionality.
2016-07-25 17:46:45 +08:00
## API
2019-07-11 14:14:33 +08:00
| Property | Description | Type | Default | Version |
| --- | --- | --- | --- | --- |
| allowClear | Show clear button, effective in multiple mode only. | boolean | false | |
| autoFocus | get focus when component mounted | boolean | false | |
| backfill | backfill selected item the input when using keyboard | boolean | false | |
2019-08-09 14:53:42 +08:00
| children (for customize input element) | customize input element | HTMLInputElement < br />< br /> HTMLTextAreaElement < br />< br /> `React.ReactElement<InputProps>` | `<Input />` | |
| children (for dataSource) | Data source to auto complete | `React.ReactElement<OptionProps>` < br />< br /> `Array<React.ReactElement<OptionProps>>` | - | |
2019-07-11 14:14:33 +08:00
| defaultActiveFirstOption | Whether active first option by default | boolean | true | |
| defaultValue | Initial selected option. | string\|string\[] | - | |
| disabled | Whether disabled select | boolean | false | |
| filterOption | If true, filter options by input, if function, filter options against it. The 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 excluded. | boolean or function(inputValue, option) | true | |
| placeholder | placeholder of input | string | - | |
| value | selected option | string\|string\[]\|{ key: string, label: string\|ReactNode }\|Array< { key: string, label: string\|ReactNode }> | - | |
2019-11-20 14:54:38 +08:00
| onBlur | Called when leaving the component. | function() | - | |
2019-07-11 14:14:33 +08:00
| onChange | Called when select an option or input value change, or value of input is changed | function(value) | - | |
2019-11-20 14:54:38 +08:00
| onFocus | Called when entering the component | function() | - | |
2019-07-11 14:14:33 +08:00
| onSearch | Called when searching items. | function(value) | - | |
| onSelect | Called when a option is selected. param is option's value and option instance. | function(value, option) | - | |
2019-11-20 14:54:38 +08:00
| defaultOpen | Initial open state of dropdown | boolean | - | |
| open | Controlled open state of dropdown | boolean | - | |
| onDropdownVisibleChange | Call when dropdown open | function(open) | - | |
2017-12-01 19:28:41 +08:00
## Methods
2019-07-11 14:14:33 +08:00
| Name | Description | Version |
| ------- | ------------ | ------- |
| blur() | remove focus | |
| focus() | get focus | |
2019-08-23 12:18:27 +08:00
## FAQ
2019-11-22 09:22:20 +08:00
### Why doesn't the text composition system work well with onSearch in controlled mode?
2019-08-23 12:18:27 +08:00
2019-11-22 09:22:20 +08:00
Please use `onChange` to manage control state. `onSearch` is used for searching input which is not same as `onChange` . Besides, clicking on the option will not trigger the `onSearch` event.
2019-08-23 12:18:27 +08:00
Related issue: [#18230 ](https://github.com/ant-design/ant-design/issues/18230 ) [#17916 ](https://github.com/ant-design/ant-design/issues/17916 )