如果本文对您有帮助,或者节约了您的时间,欢迎打赏瓶饮料,建立下友谊关系。
本博客不欢迎:各种镜像采集行为。请尊重原创文章内容,转载请保留链接信息。

mac系统中,electron的菜单是和主窗口是分离的。所以对于主窗口来说,并没有太多视觉上的影响。而在win系统中,菜单和主窗体是连在一起,不可分割的。这个时候,这些菜单就显得有些多余。那么苏南大叔就再次diy一下,隐藏electron的菜单。

注意:默认情况下,如果你不做代码干涉的话,在开发的时候,菜单是显得比较多的。但是打包之后,就都会消失的。放心。

隐藏菜单代码

注意:mac下的菜单是不能隐藏的!win以及linux系列是可以隐藏的!

代码如下:

let mainWindow
//const {Menu} = require('electron')
const Menu = electron.Menu
function createWindow () {
  Menu.setApplicationMenu(null)
  mainWindow = new BrowserWindow({width: 800, height: 600})
  mainWindow.loadURL("https://electron.org.cn/")
  mainWindow.on('closed', function () {
    mainWindow = null
  })
}

关键代码见下图:

如何隐藏 electron 窗体的菜单? - menu_1
如何隐藏 electron 窗体的菜单?(图5-1)

如果你在main的顶部定义了electron,那么你就可以使用下面的代码。

const electron = require('electron')
//...
const Menu = electron.Menu
function createWindow () {
  Menu.setApplicationMenu(null)
  //...
}

当然,你也可以从electron这个lib里面,再次导入Menu对象。见下面的代码。

const {Menu} = require('electron')
function createWindow () {
  Menu.setApplicationMenu(null)
  //...
}

效果都是一致的,这段代码只能放在主进程的ready之后使用,建议放在createWindow函数里面。渲染进程中,如果想修改menu的话,是不能这样使用的。请谨记。

更多menu相关文档,请点击这里查看:

菜单隐藏效果(win)

window下,删除菜单前效果图:

如何隐藏 electron 窗体的菜单? - menu_0
如何隐藏 electron 窗体的菜单?(图5-2)

window下,删除菜单后效果图:

如何隐藏 electron 窗体的菜单? - menu_2
如何隐藏 electron 窗体的菜单?(图5-3)

菜单隐藏效果(mac)

然而,这个删除顶部菜单的方法,只在windowslinux版本上有效。在mac系统下无效,mac系统下还是会存在顶部的菜单栏。但是mac版本下,本来主窗体和菜单也是分开的。所以整体来说,效果本来还是不错的。

如何隐藏 electron 窗体的菜单? - mac_menu
如何隐藏 electron 窗体的菜单?(图5-4)

对于mac版本来说,默认情况下(就是没有对菜单进行设置的话),开发版的时候,菜单比较多(见上图)。打包release之后,就只有一个菜单了(见下图)。

如何隐藏 electron 窗体的菜单? - 000
如何隐藏 electron 窗体的菜单?(图5-5)

总结

苏南大叔分享了删除顶部菜单的方法,更多相关菜单设置的方式,苏南大叔将会在后续文章中讲述。https://newsn.net/tag/electron/

本文涉及的electronapi的说明,见这里:https://electron.org.cn/doc/api/menu.html

 【源码】代码片段及相关软件点此获取

 【electron】秘籍文章入口,仅传授于有缘之人   electron

本站的忠实读者小伙伴,正在阅读下面这些文章:

欢迎转载传播本篇原创文章,转载请保留链接及作者信息。
欢迎指正文字或逻辑错误,将会择优在文末列出您的信息。
本站采用创作共用版权协议, 要求署名、非商业用途和相同方式共享。
转载本站内容必须也遵循“署名-非商业用途-相同方式共享”的创作共用协议。
未经许可,规模化镜像抄袭本站内容的行为,将会根据有关法律法规进行维权。
程序如此灵动~》下所有原创文章,如被用于商业用途,请您按规定支付稿费。

苏南大叔需要你的支持

感谢您的打赏,让我更有动力,将更多精彩教程文章,呈现给大家!谢谢!