上一篇文章已经分享了,如何准备Electron的基础环境了。但是博客刚发才一天,就发现有人问问题了。经过实践发现,严格按照作者的博客教程走是不会有问题的,其中包括安装的环境版本等都要一致。因为昨天发的博客,今天我发现,Electron就已经从27.0.2升级到27.0.3了。
配置main属性,main属性表示Electron的主程序的入口(Electron里头区分主程序和渲染进程,简单理解:主程序就是Electron[负责跟操作系统交互的程序],渲染进程就是我们常规的前端页面程序了)。笔者配置如下:
"main": "main.js",
表示主程序的入口文件为跟package.json一个层级的main.js文件。所以这个时候你就可以立马创建一个空的main.js了,如下:

检查package.json的scripts节点是否已经配置了如下的启动命令:
- "scripts": {
- "start": "electron .",
如果有,就忽略,如果没有的话,配置下,待会运行项目依赖这个命令行。
主程序,需要包含桌面应用的入口,也就是我们前端界面的index.html。下面是一个最简单的main.js案例:
- const { app, BrowserWindow} = require('electron')
-
- /**
- * 创建窗口
- */
- function createWindow () {
- const mainWindow = new BrowserWindow({
- width: 800,
- height: 600
- })
-
- // 窗口全屏
- // mainWindow.fullScreen = true
- // 禁止手动调整窗口大小
- // mainWindow.resizable = false
- // 加载要打包的html文件 index.html
- mainWindow.loadFile('./src/helloWorld.html')
- // 默认打开调试工具
- mainWindow.webContents.openDevTools()
- }
-
- /**
- * 监听应用状态
- */
- app.whenReady().then(() => {
- createWindow()
-
- app.on('activate', () => {
- if (BrowserWindow.getAllWindows().length === 0) {
- createWindow()
- }
- })
- })
-
- app.on('window-all-closed', () => {
- if (process.platform !== 'darwin') {
- app.quit()
- }
- })
上面的案例,可以直接复制到我们刚刚创建的main.js里头。不用做任何的调整,相关的代码块也已经做了注释了。
需要注意的一个就是,我们加载的前端入口路径是:./src/helloWorld.html,因此我们需要在当前项目下面创建src文件夹,并且创建hellowWorld.html文件,如下:

helloWorld.html里头的内容就随意了,主要是为了入门案例的演示。大家要是懒得话,可以直接复制下面的代码即可:
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
- <title>Hello Worldtitle>
- head>
- <body>
- <h1>Electronh1>,您好!
- body>
- html>
vscode的terminal终端上执行如下命令:
npm start
就会看到Electron项目启动了,效果如下:

如上图,效果像打开了F12的浏览器。其中右边的调试窗口是因为我们在main.js里头设置了:
- // 默认打开调试工具
- mainWindow.webContents.openDevTools()
这个很重要,后面的开发过程要用到,所以我就直接打开了。
好了。最简单的Electron的案例,到此就结束了。开胃菜,不知道是否能够调起大家的胃口,如果可以的话,后面还有加餐菜,大家感兴趣的话,可以继续看下一篇。
下一篇介绍,最简单的Electron桌面应用打包。