mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-15 08:59:15 +08:00
62 lines
1.1 KiB
TypeScript
62 lines
1.1 KiB
TypeScript
import React from 'react';
|
|
import type { CascaderProps } from 'antd';
|
|
import { Cascader } from 'antd';
|
|
|
|
interface Option {
|
|
value: string | number;
|
|
label: string;
|
|
children?: Option[];
|
|
disableCheckbox?: boolean;
|
|
}
|
|
|
|
const options: Option[] = [
|
|
{
|
|
label: 'Light',
|
|
value: 'light',
|
|
children: new Array(20)
|
|
.fill(null)
|
|
.map((_, index) => ({ label: `Number ${index}`, value: index })),
|
|
},
|
|
{
|
|
label: 'Bamboo',
|
|
value: 'bamboo',
|
|
children: [
|
|
{
|
|
label: 'Little',
|
|
value: 'little',
|
|
children: [
|
|
{
|
|
label: 'Toy Fish',
|
|
value: 'fish',
|
|
disableCheckbox: true,
|
|
},
|
|
{
|
|
label: 'Toy Cards',
|
|
value: 'cards',
|
|
},
|
|
{
|
|
label: 'Toy Bird',
|
|
value: 'bird',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
];
|
|
|
|
const onChange: CascaderProps<Option, 'value', true>['onChange'] = (value) => {
|
|
console.log(value);
|
|
};
|
|
|
|
const App: React.FC = () => (
|
|
<Cascader
|
|
style={{ width: '100%' }}
|
|
options={options}
|
|
onChange={onChange}
|
|
multiple
|
|
maxTagCount="responsive"
|
|
/>
|
|
);
|
|
|
|
export default App;
|