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

相关推荐
午安~婉1 天前
Electron桌面应用(续3)
前端·javascript·electron·重构通用模型·异步可迭代对象
午安~婉1 天前
Electron桌面应用(续2)
前端·javascript·electron·路由守卫·优化llm返回的内容
垚森3 天前
我用AI写了一个颜值拉满的桌面媒体播放器,全程没动一行代码,这就是AI编程新范式
ai·electron·react·opencode
光影少年3 天前
前端开发桌面端都有哪些框架?
前端·react.js·electron
萑澈4 天前
Windows 7 运行 Electron 安装包报“不是有效的 Win32 应用程序”怎么办
javascript·windows·electron
你的牧游哥4 天前
Electron核心api详解
前端·javascript·electron
jingxindeyi5 天前
electron 配置 shadcn-ui
javascript·ui·electron
天天进步20155 天前
[前端篇] 桌面端与 AI 的碰撞:Toonflow 基于 Electron 的高效交互实现
前端·人工智能·electron
浩星6 天前
electron系列9:调用原生能力,剪贴板、通知、开机自启
前端·javascript·electron
浩星6 天前
electron系列8之Electron + Vue 3:构建现代化桌面应用(下)
前端·vue.js·electron