Bootstrap

【Electron学习笔记(一)】Electron基本介绍和环境搭建

Electron基本介绍和环境搭建

前言

Electron 是一个由 GitHub 开发和维护的开源框架,它允许开发者使用 HTML、CSS 和 JavaScript 这三种前端开发技术来构建跨平台的桌面应用程序。这一特性极大地降低了桌面应用开发的门槛,使得广大 Web 开发者能够轻松地将他们的技能迁移到桌面应用领域,无需掌握复杂的原生开发语言或框架。
然而,对于初学者来说,Electron 的环境搭建和初步使用可能会遇到一些挑战。本文将深入浅出地介绍 Electron 的基本概念、核心原理以及如何进行环境搭建,帮助读者快速上手 Electron 开发。我们将从安装 Node.js 和 npm(Node 包管理器)开始,逐步指导读者完成 Electron 的全局安装,并创建一个简单的 Electron 应用项目。通过实例演示,读者将能够直观感受到 Electron 开发的乐趣和高效。
笔记源于:禹神:一小时快速上手Electron,前端Electron开发教程

正文

1、Electron介绍

1.1 什么是Electron

官网(Electron)中是这么介绍的:Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。

通过网上的一些文章和教程总结就是:Electron是一款应用广泛的跨平台的用前端Web技术开发的桌面应用开发框架

1.2 Electron技术架构

Electron = Chromium + Node.js + Native API

  • Chromium :是一个开源浏览器项目,提供了一种安全、快速、稳定的方法来体验Web;支持最新特性的浏览器,为Electron提供了强大的UI能力,可以不考虑兼容性的情况下,利用强大的Web生态来开发界面。
  • Node.js :是一个免费、开源、跨平台的 JavaScript 运行时环境, 它让开发人员能够创建服务器 Web 应用、命令行工具和脚本,让Electron有了底层的操作能力(可实现文件读写等,甚至是集成C++等操作);
  • Native API :是一套对外接口基于 Node.js N-API 规范开发的原生模块扩展开发框架,提供统一的跨平台的原生界面能力。

1.3 Electron工作流程

Electron 由一个主进程(Main Process)和若干个渲染进程(Render Process1、Render Process2、Render Process3…)组成
在这里插入图片描述

主进程(Main Process)是纯粹的Node.js ,主进程管理渲染进程(Render Process )也就是浏览器环境

主进程与渲染进程之间基于IPC通信机制进行通信,主进程可以调用远程API(Windows、Linux、Mac)

2、Electron环境搭建

2.1 创建项目目录

在这里插入图片描述

2.2 检查 Node.js 和 npm 的版本信息

终端输入以下命令:

node -v
npm -v

在这里插入图片描述

2.3 初始化 npm 包

init 初始化命令会提示在项目初始化配置中设置一些值

npm init
npm init --Yes

在这里插入图片描述
运行之后会在根目录下创建 package.json 文件
在这里插入图片描述
author 与 description 可为任意值,但对于应用打包是必填项
在这里插入图片描述
入口文件 应为 main.js
在这里插入图片描述

2.4 将 electron 包安装到应用的开发依赖中

终端输入以下命令:

npm i electron -D

在这里插入图片描述
运行之后会在根目录下创建 package-lock.json 文件
在这里插入图片描述

2.5 增加 start 命令

在 package.json 配置文件中的 scripts 字段下增加一条 start 命令:

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

在这里插入图片描述

2.6 创建 main.js 文件

写这样一段代码:

const {app,BrowserWindow}=require("electron") 

app.on("ready",()=>{
    new BrowserWindow({
        width:800,
        height:600
    })
})

要将 main.js 文件加载进应用窗口中需要两个 Electron 模块:

  • app 模块,它控制应用程序的事件生命周期。
  • BrowserWindow 模块,它创建和管理应用程序窗口。

在主进程运行 Node.js,可以将这些导入为 CommonJS 模块位于 main.js 文件顶端:

const { app, BrowserWindow } = require('electron')

在 Electron 中,只有在 app 模块的 ready 事件被激发后才能创建浏览器窗口,通过使用 app.whenReady() API来监听此事件。
在这里插入图片描述
终端输入以下命令:

 npm start

在这里插入图片描述
会得到如上图的窗口,如果想隐藏菜单栏 在配置项中加入这样一句话:autoHideMenuBar:true

const {app,BrowserWindow}=require("electron") 

app.on("ready",()=>{
    new BrowserWindow({
        width:800,
        height:600,
        autoHideMenuBar:true
    })
})

在这里插入图片描述

2.7 加载页面

使用 loadURL("") 方法载入页面

const {app,BrowserWindow}=require("electron") 

app.on("ready",()=>{
    const win = new BrowserWindow({
        width:800,
        height:600,
        autoHideMenuBar:true
    })
    win.loadURL("https://www.electronjs.org/zh/docs/latest/tutorial/quick-start")
})

在这里插入图片描述
截止目前,已经创建一个简单的 Electron 应用项目。

;