Electron去掉窗口边框并添加关闭按钮

在 Electron 中,如果你想去掉默认的窗口边框(frame)并添加额外的按键,你可以通过以下步骤来实现:

  1. 去掉默认的窗口边框

使用 BrowserWindowframe 选项,并将其设置为 false 来创建一个无边框的窗口。

javascript 复制代码
const { BrowserWindow } = require('electron')

let win = new BrowserWindow({
  width: 800,
  height: 600,
  frame: false // 这里设置为 false 去掉边框
})
  1. 添加额外的按键

有几种方法可以实现这一点,但最常见的是使用 HTML/CSS/JavaScript 在你的 Electron 应用的页面中添加自定义的 UI 元素,这些元素可以充当窗口的关闭、最小化和最大化按钮。

你可以使用 Electron 的 IPC(进程间通信)机制来监听这些按钮的点击事件,并使用 Electron 的 API 来控制窗口(如关闭、最小化或最大化)。

例如,你可以在渲染进程(renderer process)中添加一个关闭按钮,并通过 IPC 将点击事件发送到主进程(main process)。然后,在主进程中处理这个事件并关闭窗口。

渲染进程(renderer.html):

html 复制代码
<!DOCTYPE html>
<html>
<body>
  <button id="close-btn">关闭</button>

  <script>
    const { ipcRenderer } = require('electron')

    document.getElementById('close-btn').addEventListener('click', () => {
      ipcRenderer.send('close-window')
    })
  </script>
</body>
</html>

主进程(main.js):

javascript 复制代码
const { BrowserWindow, ipcMain } = require('electron')

let win = new BrowserWindow({ /* ... */ })

ipcMain.on('close-window', () => {
  win.close()
})
  1. 处理窗口拖动

由于你移除了默认的窗口边框,你可能还需要处理窗口的拖动。这可以通过监听鼠标事件并在适当的时候调用 Electron 的 move 方法来实现。

例如,你可以添加一个全屏的透明层,并在其上监听 mousedownmousemovemouseup 事件来模拟窗口的拖动。

请注意,这些只是基本的实现思路,并且可能需要根据你的具体需求进行调整。例如,你可能还需要处理窗口的最小化和最大化逻辑,以及可能的跨平台兼容性问题。

相关推荐
花随叶落5 分钟前
JavaScript的学习之DOM的查询(一)
前端·javascript·学习
念晚91726 分钟前
Linux各种命令——tac命令,more 命令, less命令,head命令,tail命令,file 命令, stat 命令
linux·运维·服务器·前端·网络·数据库·less
攻城狮方叔1 小时前
共有5部手机,如果通过服务器让1号手机执行打开 “闲鱼.js“ 脚本
服务器·javascript·vscode
追风的木木1 小时前
vue 组件el-tree添加结构指示线条
前端·javascript·vue.js
Sca_杰1 小时前
vue使用glide.js实现轮播图(可直接复制使用)
javascript·vue.js·glide
nenye2331 小时前
vue-cli 搭建项目,ElementUI的搭建和使用
前端·javascript·vue.js
snows_l1 小时前
基于 elementUI / elementUI plus,实现 主要色(主题色)的一件换色(换肤)
前端·javascript·elementui
CoCo玛奇朵1 小时前
CleanMyMacX2024免费且强大的mac电脑系统优化工具
开发语言·javascript·macos·ffmpeg·ecmascript·百度云
Wang's Blog1 小时前
Webpack: 深入理解图像加载原理与最佳实践
前端·webpack
장숙혜2 小时前
解决“Duplicate keys detected: ‘ ‘.This may cause an update error.”问题
前端·vue.js