Electron初步体验

659 阅读1分钟

Electron 安装

创建一个最简单的 Electron App,来体验下 Electron 。

目录结构

.
├── index.html
├── main.js
└── package.json

安装

npm install electron --save-dev

在 package.json 的 script 中添加 start 命令

{
  ...
  "scripts": {
    "start": "electron ."
  },
  ...
}

main.js

// 从 electron 导入相应的模块
const { app, BrowserWindow } = require('electron')

function createWindow () {
  // 创建窗口 大小为 800x600
  const win = new BrowserWindow({
    width: 800,
    height: 600,
  })
  // 加载 index.html 文件
  win.loadFile('index.html')
}

// whenReady 为 app 的生命周期方法,在该生命周期中调用 createWindow 去创建窗口
app.whenReady().then(createWindow)

// 添加监听事件:在最后一个窗口被关闭时,非 macos 的平台应用将退出
app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') {
    app.quit()
  }
})

// 添加监听事件:当应用程序激活后没有可见窗口时,创建新的浏览器窗口
app.on('activate', () => {
  if (BrowserWindow.getAllWindows().length === 0) {
    createWindow()
  }
})

index.html

只是一个 hello world 的展示

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>hello world</title>
</head>
<body>
  hello world
</body>
</html>

运行结果

运行 npm run start

image.png

Electron 打包

安装 electron-builder

npm install --save-dev electron-builder

添加 dist 命令

{
...
  "scripts": {
    "start": "electron .",
    "dist": "export CSC_IDENTITY_AUTO_DISCOVERY=false && electron-builder"
  },
  ...
}

注:在 mac 上运行 dist 命令时,会有签名的步骤,将 CSC_IDENTITY_AUTO_DISCOVERY 设置为 false,可以跳过签名。

运行结果

运行 npm run dist

在项目根目录下生成 dist 文件夹,dist/mac/electron-vue3.app 是可执行文件。我们也可以看出来生成的文件还是比较大的,有 182MB

image.png

参考