[ electron | ipc通信 ] 自定义标题栏,实现 最小化、最大化、关闭、全屏

本文介绍了如何在 Electron 应用中创建无边框窗口并自定义标题栏,通过IPC通信实现最小化、最大化、关闭和全屏功能。详细步骤包括设置BrowserWindow实例、布局功能图标、添加点击事件、监听与响应窗体事件。
摘要由CSDN通过智能技术生成

前置步骤:BrowserWindow 实例化,将 frame 设为 false

创建无边框窗口,即不带外壳(包括窗口边框、工具栏等),只含有网页内容的窗口。

// 创建浏览器窗口
win = new BrowserWindow({
  width: 1200,
  height: 800,
  frame: false,
  webPreferences: {
    nodeIntegration: true
  }
})

第一步:布局功能图标

第二步:为功能图标添加点击事件

/**
* 点击功能菜单时事件
* @param menuType 菜单类型 (可选值:minimize maximize close fullScreen)
*/
onActionMenuClick(menuType: string) {
    ipcRenderer.send('main', new Message('frameController', menuType))
}

其中 Message 是为了统一前后端的通讯格式而创建的类

export default class Message {
  action: string
  data: any
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值