Electron入门学习

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

    

    Hello World!

    

    

Hello World!

    

        We are using Node.js ,

        Chromium ,

        and Electron .

    

定义预加载脚本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的文件即为安装包,如下:

你可能感兴趣的:(Electron入门学习)