mirror of
https://github.com/ant-design/ant-design.git
synced 2024-12-13 15:49:10 +08:00
56 lines
1.1 KiB
TypeScript
56 lines
1.1 KiB
TypeScript
import React, { useState } from 'react';
|
|
import { DownOutlined } from '@ant-design/icons';
|
|
import type { DropdownProps, MenuProps } from 'antd';
|
|
import { Dropdown, Space } from 'antd';
|
|
|
|
const App: React.FC = () => {
|
|
const [open, setOpen] = useState(false);
|
|
|
|
const handleMenuClick: MenuProps['onClick'] = (e) => {
|
|
if (e.key === '3') {
|
|
setOpen(false);
|
|
}
|
|
};
|
|
|
|
const handleOpenChange: DropdownProps['onOpenChange'] = (nextOpen, info) => {
|
|
if (info.source === 'trigger' || nextOpen) {
|
|
setOpen(nextOpen);
|
|
}
|
|
};
|
|
|
|
const items: MenuProps['items'] = [
|
|
{
|
|
label: 'Clicking me will not close the menu.',
|
|
key: '1',
|
|
},
|
|
{
|
|
label: 'Clicking me will not close the menu also.',
|
|
key: '2',
|
|
},
|
|
{
|
|
label: 'Clicking me will close the menu.',
|
|
key: '3',
|
|
},
|
|
];
|
|
|
|
return (
|
|
<Dropdown
|
|
menu={{
|
|
items,
|
|
onClick: handleMenuClick,
|
|
}}
|
|
onOpenChange={handleOpenChange}
|
|
open={open}
|
|
>
|
|
<a onClick={(e) => e.preventDefault()}>
|
|
<Space>
|
|
Hover me
|
|
<DownOutlined />
|
|
</Space>
|
|
</a>
|
|
</Dropdown>
|
|
);
|
|
};
|
|
|
|
export default App;
|