菜单项
类:菜单项
向原生的应用菜单和 context 菜单添加菜单项。
进程: Main
查看 Menu 的示。
new MenuItem(options)
optionsObjectclickFunction (可选) - 当菜单项被点击的时候,使用click(menuItem,browserWindow)调用。menuItemMenuItembrowserWindowBrowserWindoweventEvent
roleString (可选) - 定义菜单项的行为,在指定click属性时将会被忽略。typeString (可选) - 取值normal,separator,submenu,checkboxorradio。labelString - (可选)sublabelString - (可选)acceleratorAccelerator (可选)icon(NativeImage | String) (可选)enabledBoolean (可选) - 如果为 false,菜单项将显示为灰色不可点击。 unclickable.visibleBoolean (可选) - 如果为 false,菜单项将完全隐藏。checkedBoolean (可选) - 只为checkbox或radio类型的菜单项。submenu(MenuItemConstructorOptions[] | Menu) (可选) - 应当作为submenu菜单项的特定类型,当它作为type: 'submenu'菜单项的特定类型时可以忽略。如果它的值不是Menu,将自动转为Menu.buildFromTemplate。idString (可选) - 标志一个菜单的唯一性。如果被定义使用,它将被用作这个菜单项的参考位置属性。positionString (可选) - 定义菜单的具体指定位置信息。
在创建菜单项时,如果有匹配的方法,建议指定 role 属性,
而不是试图手动实现在一个 click 函数中的行为。
内置的 role 行为将提供最好的原生体验。
当使用 role' 时,label' 和 accelerator 是可选的,默认为
到每个平台的适当值。
role属性值可以为:
undoredocutcopypastepasteandmatchstyleselectalldeleteminimize- 最小化当前窗口close- 关闭当前窗口quit- 退出应用程序reload- 正常重新加载当前窗口forcereload- 忽略缓存并重新加载当前窗口toggledevtools- 在当前窗口中切换开发者工具togglefullscreen- 在当前窗口中切换全屏模式resetzoom- 将对焦页面的缩放级别重置为原始大小zoomin- 将聚焦页面缩小10%zoomout- 将聚焦页面放大10%
在 macOS 上,role 还可以有以下值:
about- 匹配orderFrontStandardAboutPanel行为hide- 匹配hide行为hideothers- 匹配hideOtherApplications行为unhide- 匹配unhideAllApplications行为startspeaking- 匹配startSpeaking行为stopspeaking- 匹配stopSpeaking行为front- 匹配arrangeInFront行为zoom- 匹配performZoom行为window- "Window" 菜单项help- "Help" 菜单项services- "Services" 菜单项
当在 macOS 上指定 role' 时,label和accelerator` 是影响MenuItem的唯一的选项
所有其他选项将被忽略。
实例属性
MenuItem 对象拥有以下属性:
menuItem.enabled
一个布尔值表示是否启用该项,此属性可以动态改变。
menuItem.visible
一个布尔值表示是否可见,此属性可以动态改变。
menuItem.checked
一个布尔值表示是否选中该项,此属性可以动态改变。
checkbox 菜单项将在选中和未选中切换 checked 属性。
radio 菜单项将在选中切换 checked 属性,并且
将关闭同一菜单中所有相邻项目的属性。
您可以为其他行为添加一个 click 函数。
menuItem.label
一个表示菜单项可见标签的字符串
menuItem.click
当 MenuItem 接收到点击事件时触发的函数