electron/docs/api/menu-item.md

131 lines
4.9 KiB
Markdown
Raw Normal View History

2016-11-15 00:24:48 +00:00
## Class: MenuItem
2015-08-28 23:19:28 +00:00
> Add items to native application menus and context menus.
2015-08-28 23:19:28 +00:00
2016-11-23 19:20:56 +00:00
Process: [Main](../glossary.md#main-process)
2016-11-03 17:26:00 +00:00
2016-06-22 04:23:07 +00:00
See [`Menu`](menu.md) for examples.
2013-09-09 07:35:57 +00:00
2016-08-22 18:29:15 +00:00
### `new MenuItem(options)`
2013-08-14 22:43:35 +00:00
* `options` Object
2016-12-29 22:11:26 +00:00
* `click` Function (optional) - Will be called with
2016-06-22 04:23:07 +00:00
`click(menuItem, browserWindow, event)` when the menu item is clicked.
2016-10-13 06:30:57 +00:00
* `menuItem` MenuItem
* `browserWindow` BrowserWindow
* `event` Event
2016-12-29 22:11:26 +00:00
* `role` String (optional) - Define the action of the menu item, when specified the
`click` property will be ignored. See [roles](#roles).
2016-12-29 22:11:26 +00:00
* `type` String (optional) - Can be `normal`, `separator`, `submenu`, `checkbox` or
2016-06-22 04:23:07 +00:00
`radio`.
2017-11-28 17:15:15 +00:00
* `label` String (optional)
* `sublabel` String (optional)
2016-12-29 22:11:26 +00:00
* `accelerator` [Accelerator](accelerator.md) (optional)
* `icon` ([NativeImage](native-image.md) | String) (optional)
* `enabled` Boolean (optional) - If false, the menu item will be greyed out and
unclickable.
2016-12-29 22:11:26 +00:00
* `visible` Boolean (optional) - If false, the menu item will be entirely hidden.
* `checked` Boolean (optional) - Should only be specified for `checkbox` or `radio` type
2016-06-22 04:23:07 +00:00
menu items.
2016-12-29 22:11:26 +00:00
* `submenu` (MenuItemConstructorOptions[] | Menu) (optional) - Should be specified for `submenu` type menu items. If
2016-06-22 04:23:07 +00:00
`submenu` is specified, the `type: 'submenu'` can be omitted. If the value
is not a `Menu` then it will be automatically converted to one using
`Menu.buildFromTemplate`.
2016-12-29 22:11:26 +00:00
* `id` String (optional) - Unique within a single menu. If defined then it can be used
2016-06-22 04:23:07 +00:00
as a reference to this item by the position attribute.
2016-12-29 22:11:26 +00:00
* `position` String (optional) - This field allows fine-grained definition of the
2016-06-22 04:23:07 +00:00
specific location within a given menu.
2015-09-02 01:19:18 +00:00
### Roles
Roles allow menu items to have predefined behaviors.
It is best to specify `role` for any menu item that matches a standard role,
rather than trying to manually implement the behavior in a `click` function.
The built-in `role` behavior will give the best native experience.
2015-09-02 01:19:18 +00:00
The `label` and `accelerator` values are optional when using a `role` and will
default to appropriate values for each platform.
2016-06-22 21:10:38 +00:00
2015-09-02 01:19:18 +00:00
The `role` property can have following values:
* `undo`
* `redo`
* `cut`
* `copy`
* `paste`
* `pasteandmatchstyle`
2015-09-02 01:19:18 +00:00
* `selectall`
* `delete`
2015-09-02 01:19:18 +00:00
* `minimize` - Minimize current window
* `close` - Close current window
2016-06-21 00:20:57 +00:00
* `quit`- Quit the application
* `reload` - Reload the current window
2017-02-02 20:01:58 +00:00
* `forcereload` - Reload the current window ignoring the cache.
* `toggledevtools` - Toggle developer tools in the current window
2016-06-21 16:43:29 +00:00
* `togglefullscreen`- Toggle full screen mode on the current window
2016-08-08 17:09:45 +00:00
* `resetzoom` - Reset the focused page's zoom level to the original size
* `zoomin` - Zoom in the focused page by 10%
* `zoomout` - Zoom out the focused page by 10%
2017-03-24 11:14:08 +00:00
* `editMenu` - Whole default "Edit" menu (Undo, Copy, etc.)
* `windowMenu` - Whole default "Window" menu (Minimize, Close, etc.)
2017-04-26 16:06:10 +00:00
The following additional roles are available on macOS:
2015-09-02 01:19:18 +00:00
* `about` - Map to the `orderFrontStandardAboutPanel` action
* `hide` - Map to the `hide` action
* `hideothers` - Map to the `hideOtherApplications` action
* `unhide` - Map to the `unhideAllApplications` action
* `startspeaking` - Map to the `startSpeaking` action
* `stopspeaking` - Map to the `stopSpeaking` action
2015-09-02 01:19:18 +00:00
* `front` - Map to the `arrangeInFront` action
* `zoom` - Map to the `performZoom` action
* `toggletabbar` - Map to the `toggleTabBar` action
* `selectnexttab` - Map to the `selectNextTab` action
* `selectprevioustab` - Map to the `selectPreviousTab` action
* `mergeallwindows` - Map to the `mergeAllWindows` action
* `movetabtonewwindow` - Map to the `moveTabToNewWindow` action
2015-09-02 01:19:18 +00:00
* `window` - The submenu is a "Window" menu
* `help` - The submenu is a "Help" menu
* `services` - The submenu is a "Services" menu
2017-11-21 01:58:47 +00:00
* `recentdocuments` - The submenu is an "Open Recent" menu
2017-11-21 00:32:49 +00:00
* `clearrecentdocuments` - Map to the `clearRecentDocuments` action
When specifying a `role` on macOS, `label` and `accelerator` are the only
options that will affect the menu item. All other options will be ignored.
2016-06-22 04:23:07 +00:00
### Instance Properties
2016-06-22 04:23:07 +00:00
The following properties are available on instances of `MenuItem`:
2016-06-22 04:23:07 +00:00
#### `menuItem.enabled`
2017-07-24 08:29:03 +00:00
A `Boolean` indicating whether the item is enabled, this property can be
2016-06-22 04:23:07 +00:00
dynamically changed.
2016-06-22 04:23:07 +00:00
#### `menuItem.visible`
2017-07-24 08:29:03 +00:00
A `Boolean` indicating whether the item is visible, this property can be
2016-06-22 04:23:07 +00:00
dynamically changed.
#### `menuItem.checked`
2017-07-24 08:29:03 +00:00
A `Boolean` indicating whether the item is checked, this property can be
2016-06-22 04:23:07 +00:00
dynamically changed.
A `checkbox` menu item will toggle the `checked` property on and off when
selected.
A `radio` menu item will turn on its `checked` property when clicked, and
2016-06-22 04:23:07 +00:00
will turn off that property for all adjacent items in the same menu.
You can add a `click` function for additional behavior.
2016-11-25 12:17:31 +00:00
#### `menuItem.label`
2017-07-24 08:29:03 +00:00
A `String` representing the menu items visible label
2016-11-25 12:17:31 +00:00
#### `menuItem.click`
2017-07-24 08:29:03 +00:00
A `Function` that is fired when the MenuItem receives a click event