ant-design/components/menu/demo/inline-collapsed.md

96 lines
2.1 KiB
Markdown
Raw Normal View History

2017-06-30 18:08:30 +08:00
---
order: 2
title:
zh-CN: 缩起内嵌菜单
en-US: Collapsed inline menu
---
## zh-CN
内嵌菜单可以被缩起/展开。
2017-09-15 21:37:17 +08:00
你可以在 [Layout](/components/layout/#components-layout-demo-side) 里查看侧边布局结合的完整示例。
2017-06-30 18:08:30 +08:00
## en-US
Inline menu could be collapsed.
2017-09-15 21:37:17 +08:00
Here is [a complete demo](/components/layout/#components-layout-demo-side) with sider layout.
```tsx
import { Menu, Button, MenuProps } from 'antd';
import {
AppstoreOutlined,
MenuUnfoldOutlined,
MenuFoldOutlined,
PieChartOutlined,
DesktopOutlined,
2020-03-11 12:31:53 +08:00
ContainerOutlined,
MailOutlined,
} from '@ant-design/icons';
2018-06-27 15:55:04 +08:00
type MenuItem = Required<MenuProps>['items'][number];
2017-06-30 18:08:30 +08:00
function getItem(
label: React.ReactNode,
key: React.Key,
icon?: React.ReactNode,
children?: MenuItem[],
type?: 'group',
): MenuItem {
return {
key,
icon,
children,
label,
type,
} as MenuItem;
}
const items: MenuItem[] = [
getItem('Option 1', '1', <PieChartOutlined />),
getItem('Option 2', '2', <DesktopOutlined />),
getItem('Option 3', '3', <ContainerOutlined />),
getItem('Navigation One', 'sub1', <MailOutlined />, [
getItem('Option 5', '5'),
getItem('Option 6', '6'),
getItem('Option 7', '7'),
getItem('Option 8', '8'),
]),
2018-06-27 15:55:04 +08:00
getItem('Navigation Two', 'sub2', <AppstoreOutlined />, [
getItem('Option 9', '9'),
getItem('Option 10', '10'),
getItem('Submenu', 'sub3', null, [getItem('Option 11', '11'), getItem('Option 12', '12')]),
]),
];
const App = () => {
const [collapsed, setCollapsed] = React.useState(false);
const toggleCollapsed = () => {
setCollapsed(!collapsed);
2019-05-07 14:57:32 +08:00
};
2018-06-27 15:55:04 +08:00
return (
<div style={{ width: 256 }}>
<Button type="primary" onClick={toggleCollapsed} style={{ marginBottom: 16 }}>
{collapsed ? <MenuUnfoldOutlined /> : <MenuFoldOutlined />}
</Button>
<Menu
defaultSelectedKeys={['1']}
defaultOpenKeys={['sub1']}
mode="inline"
theme="dark"
inlineCollapsed={collapsed}
items={items}
/>
</div>
);
};
2017-06-30 18:08:30 +08:00
ReactDOM.render(<App />, mountNode);
2019-05-07 14:57:32 +08:00
```