90 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Markdown
		
	
	
			
		
		
	
	
			90 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Markdown
		
	
	
| ---
 | |
| category: Components
 | |
| type: Data Entry
 | |
| cols: 2
 | |
| title: AutoComplete
 | |
| cover: https://gw.alipayobjects.com/zos/alicdn/qtJm4yt45/AutoComplete.svg
 | |
| ---
 | |
| 
 | |
| Autocomplete function of input field.
 | |
| 
 | |
| ## When To Use
 | |
| 
 | |
| - When you need an input box instead of a selector.
 | |
| - When you need input suggestions or helping text.
 | |
| 
 | |
| The differences with Select are:
 | |
| 
 | |
| - AutoComplete is an input box with text hints, and users can type freely. The keyword is aiding **input**.
 | |
| - Select is selecting among given choices. The keyword is **select**.
 | |
| 
 | |
| ## API
 | |
| 
 | |
| ```html
 | |
| <a-auto-complete v-model:value="value" :options="options" />
 | |
| ```
 | |
| 
 | |
| | 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 |  |
 | |
| | default (for customize input element) | customize input element | slot | `<Input />` |  |
 | |
| | defaultActiveFirstOption | Whether active first option by default | boolean | true |  |
 | |
| | defaultOpen | Initial open state of dropdown | boolean | - |  |
 | |
| | disabled | Whether disabled select | boolean | false |  |
 | |
| | dropdownMatchSelectWidth | Determine whether the dropdown menu and the select input are the same width. Default set `min-width` same as input. Will ignore when value less than select width. `false` will disable virtual scroll | boolean \| number | true |  |
 | |
| | dropdownMenuStyle | additional style applied to dropdown menu | object |  | 1.5.0 |
 | |
| | 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 |  |
 | |
| | open | Controlled open state of dropdown | boolean | - |  |
 | |
| | option | custom render option by slot | v-slot:option="{value, label, [disabled, key, title]}" | - | 3.0 |
 | |
| | options | Data source for autocomplete | [DataSourceItemType](https://github.com/vueComponent/ant-design-vue/blob/724d53b907e577cf5880c1e6742d4c3f924f8f49/components/auto-complete/index.vue#L9)\[] |  |  |
 | |
| | placeholder | placeholder of input | string | - |  |
 | |
| | v-model:value | selected option | string\|string\[]\|{ key: string, label: string\|vNodes }\|Array<{ key: string, label: string\|vNodes }> | - |  |
 | |
| 
 | |
| ### events
 | |
| 
 | |
| | Events Name | Description | Arguments | Version |  |
 | |
| | --- | --- | --- | --- | --- |
 | |
| | blur | Called when leaving the component. | function() |  |  |
 | |
| | change | Called when select an option or input value change, or value of input is changed | function(value) |  |  |
 | |
| | dropdownVisibleChange | Call when dropdown open | function(open) |  |  |
 | |
| | focus | Called when entering the component | function() |  |  |
 | |
| | search | Called when searching items. | function(value) | - |  |
 | |
| | select | Called when a option is selected. param is option's value and option instance. | function(value, option) |  |  |
 | |
| 
 | |
| ## Methods
 | |
| 
 | |
| | Name    | Description  | Version |
 | |
| | ------- | ------------ | ------- |
 | |
| | blur()  | remove focus |         |
 | |
| | focus() | get focus    |         |
 | |
| 
 | |
| ## FAQ
 | |
| 
 | |
| ### Part of the api in v2 are not available in v3?
 | |
| 
 | |
| AutoComplete is an Input component that supports auto complete tips. As such, it should not support props like `labelInValue` that affect value display. In v3, the AutoComplete implementation can not handle the case where the `value` and `label` are identical. v4 not longer support `label` as the value input.
 | |
| 
 | |
| Besides, to unify the API, `dataSource` is replaced with `options`. You can migrate with the following change:
 | |
| 
 | |
| #### v2
 | |
| 
 | |
| ```ts
 | |
| dataSource = ['light', 'bamboo'];
 | |
| // or
 | |
| dataSource = [
 | |
|   { value: 'light', text: 'Light' },
 | |
|   { value: 'bamboo', text: 'Bamboo' },
 | |
| ];
 | |
| ```
 | |
| 
 | |
| #### v3
 | |
| 
 | |
| ```ts
 | |
| options = [
 | |
|   { value: 'light', label: 'Light' },
 | |
|   { value: 'bamboo', label: 'Bamboo' },
 | |
| ];
 | |
| ```
 |