【Web】Electron:第一个桌面程序

Electron 是一个开源框架,使开发者能够使用 HTML、CSS 和 JavaScript 构建跨平台的桌面应用程序。通过 Electron,开发者可以将网页技术应用于桌面软件开发,从而利用现有的网页技术栈构建功能强大的桌面应用。

下载 Electron

虽然 Electron 可以通过 npm 安装,但由于某些网络问题或权限问题,可能会导致安装失败。因此,本指南将介绍如何直接从 Electron 的 GitHub Releases 页面下载 Electron 并使用。

  • 访问 Electron Releases 页面

    打开 Electron Releases 页面。

  • 选择版本

    找到你想要下载的 Electron 版本,通常选择最新版本。

  • 下载适合的文件

    根据你的操作系统下载适合的预编译二进制文件。对于 Windows,通常下载 electron-vX.X.X-win32-x64.zip 文件(X.X.X 为版本号)。

解压文件

将下载的 .zip 文件解压到你选择的目录,例如 D:\code\electron

创建最小的 Electron Demo

接下来,我们将创建一个简单的 Electron 应用程序。

  • 创建项目目录

    在你选择的工作目录下创建一个新文件夹,例如 D:\code\my-electron-app

    bash 复制代码
    mkdir D:\code\my-electron-app
    cd D:\code\my-electron-app
  • 创建 index.html 文件

    在项目目录下创建一个 index.html 文件,并添加以下内容:

    html 复制代码
    <!DOCTYPE html>
    <html>
    <head>
        <title>Hello Electron</title> <!-- 设置网页标题 -->
    </head>
    <body>
        <h1>Hello, Electron!</h1> <!-- 页面显示的主标题 -->
    </body>
    </html>
  • 创建 index.js 文件

    在同一目录下创建一个 main.js 文件,并添加以下内容:

    javascript 复制代码
    // 引入 Electron 模块
    const { app, BrowserWindow } = require('electron');
    
    // 创建主窗口的函数
    function createWindow() {
        // 创建一个新的浏览器窗口
        const win = new BrowserWindow({
            width: 800, // 窗口宽度
            height: 600, // 窗口高度
            webPreferences: {
                nodeIntegration: true // 启用 Node.js 集成,以便在渲染进程中使用 Node.js API
            }
        });
    
        // 加载 index.html 文件到窗口
        win.loadFile('index.html');
    }
    
    // 当 Electron 完成初始化时调用 createWindow 函数
    app.whenReady().then(createWindow);
    
    // 处理所有窗口关闭事件
    app.on('window-all-closed', () => {
        // 对于非 macOS 系统,退出应用
        if (process.platform !== 'darwin') {
            app.quit();
        }
    });
    
    // 处理应用被激活时的事件
    app.on('activate', () => {
        // 如果没有打开的窗口,则重新创建一个窗口
        if (BrowserWindow.getAllWindows().length === 0) {
            createWindow();
        }
    });

运行 Electron 应用

  • 在命令行中运行 Electron

    打开命令行,导航到你的应用程序目录,然后运行 Electron:

    bash 复制代码
    cd D:\code\my-electron-app
    path\to\your\electron\executable\electron.exe .

    例如,如果你将 Electron 解压到 D:\code\electron,命令应为:

    bash 复制代码
    D:\code\electron\electron.exe .

打包你的应用

如果你希望打包应用,可以使用 Electron 的打包工具。

  • 下载 Electron Packager

    下载 Electron Packager

  • 使用 Electron Packager 打包

    • electron-packager 解压到你的项目目录。
    • 使用以下命令打包你的应用:
    bash 复制代码
    path\to\your\electron\packager\executable\electron-packager . MyApp --platform=win32 --arch=x64

    这将生成一个 MyApp-win32-x64 文件夹,其中包含你的应用的可执行文件。

相关推荐
小镇程序员3 分钟前
vue2 src_Todolist全局总线事件版本
前端·javascript·vue.js
野槐5 分钟前
前端图像处理(一)
前端
程序猿阿伟12 分钟前
《智能指针频繁创建销毁:程序性能的“隐形杀手”》
java·开发语言·前端
疯狂的沙粒14 分钟前
对 TypeScript 中函数如何更好的理解及使用?与 JavaScript 函数有哪些区别?
前端·javascript·typescript
瑞雨溪22 分钟前
AJAX的基本使用
前端·javascript·ajax
力透键背25 分钟前
display: none和visibility: hidden的区别
开发语言·前端·javascript
程楠楠&M36 分钟前
node.js第三方Express 框架
前端·javascript·node.js·express
weiabc36 分钟前
学习electron
javascript·学习·electron
盛夏绽放44 分钟前
Node.js 和 Socket.IO 实现实时通信
前端·后端·websocket·node.js
想自律的露西西★1 小时前
用el-scrollbar实现滚动条,拖动滚动条可以滚动,但是通过鼠标滑轮却无效
前端·javascript·css·vue.js·elementui·前端框架·html5