mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-07 20:08:21 +08:00
51 lines
1.1 KiB
TypeScript
51 lines
1.1 KiB
TypeScript
|
import React, { useState } from 'react';
|
||
|
import { AutoComplete } from 'antd';
|
||
|
|
||
|
const mockVal = (str: string, repeat = 1) => ({
|
||
|
value: str.repeat(repeat),
|
||
|
});
|
||
|
|
||
|
const App: React.FC = () => {
|
||
|
const [value, setValue] = useState('');
|
||
|
const [options, setOptions] = useState<{ value: string }[]>([]);
|
||
|
|
||
|
const onSearch = (searchText: string) => {
|
||
|
setOptions(
|
||
|
!searchText ? [] : [mockVal(searchText), mockVal(searchText, 2), mockVal(searchText, 3)],
|
||
|
);
|
||
|
};
|
||
|
|
||
|
const onSelect = (data: string) => {
|
||
|
console.log('onSelect', data);
|
||
|
};
|
||
|
|
||
|
const onChange = (data: string) => {
|
||
|
setValue(data);
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<>
|
||
|
<AutoComplete
|
||
|
options={options}
|
||
|
style={{ width: 200 }}
|
||
|
onSelect={onSelect}
|
||
|
onSearch={onSearch}
|
||
|
placeholder="input here"
|
||
|
/>
|
||
|
<br />
|
||
|
<br />
|
||
|
<AutoComplete
|
||
|
value={value}
|
||
|
options={options}
|
||
|
style={{ width: 200 }}
|
||
|
onSelect={onSelect}
|
||
|
onSearch={onSearch}
|
||
|
onChange={onChange}
|
||
|
placeholder="control mode"
|
||
|
/>
|
||
|
</>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default App;
|