mirror of
https://github.com/ant-design/ant-design.git
synced 2025-01-01 05:38:03 +08:00
80 lines
1.6 KiB
TypeScript
80 lines
1.6 KiB
TypeScript
import React from 'react';
|
|
import type { CascaderProps } from 'antd';
|
|
import { Cascader } from 'antd';
|
|
|
|
const { SHOW_CHILD } = Cascader;
|
|
|
|
interface Option {
|
|
value: string | number;
|
|
label: string;
|
|
children?: Option[];
|
|
}
|
|
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',
|
|
},
|
|
{
|
|
label: 'Toy Cards',
|
|
value: 'cards',
|
|
},
|
|
{
|
|
label: 'Toy Bird',
|
|
value: 'bird',
|
|
},
|
|
],
|
|
},
|
|
],
|
|
},
|
|
];
|
|
|
|
const App: React.FC = () => {
|
|
const onChange: CascaderProps<Option, 'value', true>['onChange'] = (value) => {
|
|
console.log(value);
|
|
};
|
|
return (
|
|
<>
|
|
<Cascader
|
|
style={{ width: '100%' }}
|
|
options={options}
|
|
onChange={onChange}
|
|
multiple
|
|
maxTagCount="responsive"
|
|
showCheckedStrategy={SHOW_CHILD}
|
|
defaultValue={[
|
|
['bamboo', 'little', 'fish'],
|
|
['bamboo', 'little', 'cards'],
|
|
['bamboo', 'little', 'bird'],
|
|
]}
|
|
/>
|
|
<br />
|
|
<br />
|
|
<Cascader
|
|
style={{ width: '100%' }}
|
|
options={options}
|
|
onChange={onChange}
|
|
multiple
|
|
maxTagCount="responsive"
|
|
defaultValue={[['bamboo']]}
|
|
/>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default App;
|