当前位置: 首页 > article >正文

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

Electron基本介绍和环境搭建

    • Electron基本介绍和环境搭建
    • 前言
    • 正文
    • 1、Electron介绍
      • 1.1 什么是Electron
      • 1.2 Electron技术架构
      • 1.3 Electron工作流程
    • 2、Electron环境搭建
      • 2.1 创建项目目录
      • 2.2 检查 Node.js 和 npm 的版本信息
      • 2.3 初始化 npm 包
      • 2.4 将 electron 包安装到应用的开发依赖中
      • 2.5 增加 start 命令
      • 2.6 创建 main.js 文件
      • 2.7 加载页面

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 应用项目。


http://www.kler.cn/a/409566.html

相关文章:

  • DICOM图像深入解析:为何部分DR/CR图像默认显示为反色?
  • Mysql的加锁情况详解
  • 桥梁、隧道、道路、铁路、结构、岩土,哪个发展更好?
  • 【bug】使用transformers训练二分类任务时,训练损失异常大
  • repmgr安装及常用运维指令
  • 部署一套开源客服系统,用户需要准备什么设备?
  • mac Parallels Desktop 20 20.1.1-55740安装windows10教程
  • 基于yolov8、yolov5的智能零售柜商品检测识别系统(含UI界面、训练好的模型、Python代码、数据集)
  • [极客大挑战 2019]BabySQL--详细解析
  • 数据库-基础理论
  • git bash是什么,git是什么,git中的暂存区是什么,git中的本地仓库是什么,git中工作目录指的是什么
  • 长三角文博会:Adobe国际认证体系推动设计人才评价新标准
  • 【C语言】深入解析assert 断言机制
  • Spring Boot 2 和 Spring Boot 3 中使用 Spring Security 的区别
  • 微信小程序页面配置详解:从入门到精通
  • MATLAB实现garch模型(广义自回归条件异方差)
  • LayaBox1.8.4实现自定义3DMesh
  • PyOCD 的基本使用
  • 详解Qt QDir路径类
  • 跨平台应用开发框架(1)----Qt(组件篇)
  • C#里怎么样实现单向链表?
  • 《图像梯度与常见算子全解析:原理、用法及效果展示》
  • [OpenGL]使用OpenGL+OIT实现透明效果
  • CPU性能优化--性能分析方法
  • 网络层协议IP
  • 【计算机网络】多路转接之select