2016-08-26 14:42:41 +08:00
---
category: Components
cols: 1
type: Navigation
2016-08-26 15:07:46 +08:00
title: Menu
2016-08-26 14:42:41 +08:00
---
Menu list of Navigation.
2016-09-10 13:43:30 +08:00
## When To Use
2016-08-26 14:42:41 +08:00
Navigation menu is important for a website, it helps users jump from one site section to another quickly. Mostly, it includes top navigation and side navigation. Top navigation provides all the category and functions of the website. Side navigation provides the Multi-level structure of the website.
More layout and samples: [layout ](/docs/spec/layout ).
```html
< Menu >
< Menu.Item > Menu< / Menu.Item >
< SubMenu title = "SubMenu" >
< Menu.Item > SubMenuItem< / Menu.Item >
< / SubMenu >
< / Menu >
```
## API
### Menu props
| Param | Description | Type | Default value |
|----------|---------------|----------|--------------|
2017-01-20 20:10:50 +08:00
| theme | color of the theme | string: `light` `dark` | `light` |
| mode | type of the menu; vertical, horizontal, and inline modes are supported | string: vertical horizontal inline | vertical |
| selectedKeys | array with the keys of currently selected menu items | string[] | |
| defaultSelectedKeys | array with the keys of default selected menu items | string[] | |
| openKeys | array with the keys of currently opened sub menus | string[] | |
2016-08-26 14:42:41 +08:00
| defaultOpenKeys | array with the keys of default opened sub menus | | |
2016-09-18 15:59:43 +08:00
| onOpenChange | called when open/close sub menu | Function(openKeys: string[]) | noop |
2016-08-26 14:42:41 +08:00
| onSelect | callback of the selected item | Function({ item, key, selectedKeys }) | none |
| onDeselect | callback of the deselected item, only supported for multiple mode | Function({ item, key, selectedKeys }) | - |
| onClick | callback of the clicked menu item, params: {item, key, keyPath} | function | - |
2017-01-20 20:10:50 +08:00
| style | style of the root node | object | |
2016-12-22 15:06:21 +08:00
| inlineIndent | indent px of inline menu item on each level | number | 24 |
2017-03-02 17:48:11 +08:00
| multiple | Allow select multiple item | boolean | false |
2016-08-26 14:42:41 +08:00
> More options in [rc-menu](https://github.com/react-component/menu#api)
### Menu.Item props
| Param | Description | Type | Default value |
|----------|----------------|----------|--------------|
2017-01-20 20:10:50 +08:00
| disabled | disabled or not | boolean | false |
| key | unique id of the menu item | string | |
2016-08-26 14:42:41 +08:00
### Menu.SubMenu props
| Param | Description | Type | Default value |
|----------|----------------|----------|--------------|
2017-01-20 20:10:50 +08:00
| disabled | disabled or not | boolean | false |
| key | unique id of the menu item | string | |
| title | title of the sub menu | string\|ReactNode | |
| children | sub menus or sub menu items | Arrat< MenuItem \|SubMenu > | |
2016-08-26 14:42:41 +08:00
| onTitleClick | callback of the clicked sub menu title | Function({ eventKey, domEvent }) | |
### Menu.ItemGroup props
| Param | Description | Type | Default value |
|----------|----------------|----------|--------------|
2017-01-20 20:10:50 +08:00
| title | title of the group | string\|ReactNode | |
2016-08-26 14:42:41 +08:00
| children | sub menu items | MenuItem[] | |
2016-11-15 14:12:25 +08:00
### Menu.Divider
divider line in between menu items, only used in vertical popup Menu or Dropdown Menu.