Electron 将网站打包成桌面程序

依赖环境:npm、node.js

main.js

javascript 复制代码
const { app, BrowserWindow, globalShortcut } = require("electron");
const path = require("path");

function createWindow() {
  const win = new BrowserWindow({
    width: 1280,
    height: 900,
    webPreferences: {
      preload: path.join(__dirname, "preload.js"),
      contextIsolation: true,
      nodeIntegration: false
    }
  });

  // 👉 如果你的 URL 是本机服务,可这样写
  win.loadURL("http://localhost:5000/view");

  // 👉 开发环境直接打开 DevTools
  // win.webContents.openDevTools();

  // 👉 注册 F12 快捷键(打包后仍可用)
  globalShortcut.register("F12", () => {
    win.webContents.openDevTools();
  });

  // 👉 右键菜单:Inspect Element
  win.webContents.on("context-menu", () => {
    win.webContents.openDevTools();
  });
}

app.whenReady().then(createWindow);

app.on("window-all-closed", () => {
  if (process.platform !== "darwin") app.quit();
});

preload.js

javascript 复制代码
// 可以留空,也可以加一些未来需要的安全暴露接口
window.addEventListener("DOMContentLoaded", () => {});

package.json

javascript 复制代码
{
  "name": "webapp-package",
  "version": "1.0.0",
  "main": "main.js",
  "scripts": {
    "start": "electron .",
    "dist": "electron-builder --win --x64",
    "build": "electron-builder"
  },
  "build": {
	"electronDownload": {
      "mirror": "https://npmmirror.com/mirrors/electron/"
    },
    "appId": "pto.webtoexe",
    "productName": "PTO",
    "win": {
      "target": [
        "nsis",
        "portable"
      ]
    }
  },
  "devDependencies": {
    "electron": "^25.0.0",
    "electron-builder": "^24.13.3"
  }
}

1、将上面三个文件放到自己文件夹目录下

2、首先在自己目录下安装electron-builder

npm install electron-builder --save-dev

3、临时环境变量并运行

set ELECTRON_MIRROR=https://npmmirror.com/mirrors/electron/

set ELECTRON_BUILDER_BINARIES_MIRROR=https://npmmirror.com/mirrors/electron-builder-binaries/

npm run build

4、dist目录下可以看到打包后的exe

相关推荐
一拳不是超人2 天前
Electron主窗口弹框被WebContentView遮挡?独立WebContentView弹框方案详解!
前端·javascript·electron
柯南95276 天前
Electron 无边框窗口拖拽实现
vue.js·electron
卸任6 天前
Windows判断是笔记本还是台式
前端·react.js·electron
一拳不是超人6 天前
Electron 实战全解析:基于 WebContentView 的多视图管理系统
前端·javascript·electron
lpfasd12310 天前
Tauri vs Electron:高质量Word/PDF导出效果深度对比
electron·pdf·word
卸任11 天前
Electron判断是内置摄像头还是接摄像头
前端·react.js·electron
贺今宵13 天前
Capacitor打包electron为apk
electron
一文解千机14 天前
wine 优化配置及显卡加速,完美运行Electron 编译的程序(新榜小豆芽、作家助手、小V猫等)
linux·ubuntu·electron·wine·wine优化配置·wine显卡加速·wine大型游戏
weixin_4255437318 天前
TREA CN 3.3.30 + GLM-5 王炸更新
ai·electron
一枚小太阳19 天前
想学 Electron?这份「能跑的示例集」一篇搞懂
前端·electron