Electron 是一个能让你使用 JavaScript, HTML 和 CSS 来创建桌面应用程序的框架。 这些应用程序可以打包后在 macOS、Windows 和 Linux 上直接运行,或者通过 Mac App Store 或微软商店进行分发。
安装之前要保证安装了最新的node和npm。
可以通过 node -v,npm -v检查Node.js 和 npm 的版本信息。
安装 Electron
> npm init -y
初始化项目package.json的时候npm init -y 默认把名字设置为electron,这边需要修改下name的值,否则后续安装会报错:Refusing to install package with name "electron" under a package
author 和 description 字段对于打包来说是必要的,空值的话后续安装会报错,所以也给它加上非空的值。
继续安装
> npm i --save-dev electron
创建主脚本文件main.js
主脚本指定了运行主进程的 Electron 应用程序的入口。通常,在主进程中运行的脚本控制应用程序的生命周期、显示图形用户界面及其元素、执行本机操作系统交互以及在网页中创建渲染进程。 Electron 应用程序只能有一个主进程。
main.js
const { app, BrowserWindow } = require('electron') //为了管理应用程序的生命周期事件以及创建和控制浏览器窗口
const path = require('path') //为操作文件路径
function createWindow () { //创建一个带有预加载脚本的新的浏览器窗口,并加载index.html文件进入该窗口
const win = new BrowserWindow({
width: 800,
height: 600,
webPreferences: {
preload: path.join(__dirname, 'preload.js')
}
})
win.loadFile('index.html')
}
app.whenReady().then(() => {
createWindow()
app.on('activate', () => { //添加一个新的侦听器
if (BrowserWindow.getAllWindows().length === 0) { //只有当应用程序激活后没有可见窗口时,才能创建新的浏览器窗口
createWindow()
}
})
})
app.on('window-all-closed', () => { //添加一个新的侦听器
if (process.platform !== 'darwin') { //当应用程序不再有任何打开窗口时试图退出。 由于操作系统的 窗口管理行为 ,此监听器在 macOS 上是禁止操作的。
app.quit()
}
})
创建网页index.html
index.html
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Hello World!</title>
<meta http-equiv="Content-Security-Policy" content="script-src 'self' 'unsafe-inline';" />
</head>
<body style="background: white;">
<h1>Hello World!</h1>
<p>
We are using Node.js <span id="node-version"></span>,
Chromium <span id="chrome-version"></span>,
and Electron <span id="electron-version"></span>.
</p>
</body>
</html>
定义预加载脚本preload.js
预加载脚本就像是Node.js和网页之间的桥梁,它允许你将特定的 API 和行为暴露到你的网页上,而不是不安全地把整个 Node.js 的 API暴露。
preload.js
window.addEventListener('DOMContentLoaded', () => {
const replaceText = (selector, text) => {
const element = document.getElementById(selector)
if (element) element.innerText = text
}
for (const type of ['chrome', 'node', 'electron']) {
replaceText(`${type}-version`, process.versions[type])
}
})
修改 package.json 文件的main为main.js;
修改 package.json 文件的scripts为 scripts:{"start": "electron ."},npm start 命令将用 Electron 来运行主脚本;
运行程序:
npm start
运行成功后打开的界面如下:
使用 Electron Forge 来打包并分发应用程序
导入 Electron Forge
npm install --save-dev @electron-forge/cli
npx electron-forge import
创建一个分发版本
npm run make
Electron-forge 会创建 out 文件夹在项目目录下,如下:
make下找到exe的文件即为安装包,如下: