Electron教程1-初学入门

玩转Electron

Electron 是什么

Electron是一个使用 JavaScript、HTML 和 CSS 构建桌面应用程序的框架。 嵌入 Chromium 和 Node.js 到 二进制的 Electron 允许您保持一个 JavaScript 代码代码库并创建 在Windows上运行的跨平台应用 macOS和Linux------不需要本地开发 经验。

注意事项

Electron 更新非常快

初期开发建议使用最新的稳定版

环境安装

于2024年11月,当前节点而言,建议安装node20.18.0

安装完成后
npm i -g cnpm
cnpm i -g electron 这样会全局安装最新版的electron

安装 vscode

终端中测试下指令运行,如果有权限问题运行以下指令

powershell 复制代码
Set-ExecutionPolicy Unrestricted
set-executionpolicy remotesigned #管理员打开ps并运行

安装 git

安装最新版Git以及TortoiseGit

第一个实例

找个目录比如E:\盘根目录

创建一个为 electron_study的目录

进入electron_study目录

右键选择使用 vscode 打开

勾选信任

创建 main.js

js 复制代码
console.log('Hello from Electron')

新建终端,在终端中
electron main.js

输出效果

powershell 复制代码
PS D:\_new_20231014\_linyee\electron_study> electron main.js

Hello from Electron

ctrl+c 退出运行,继续后续代码测试

第二个实例

powershell 复制代码
# Clone this repository
git clone https://github.com/electron/electron-quick-start
# Go into the repository
cd electron-quick-start
# Install dependencies
cnpm i
# Run the app
npm start

网速慢的、克隆不下来的同学 从这里直接去下载

第二个实例解读

main.js 是入口文件,负责创建窗口并加载index.html

preload.js 是一个预加载文件,在加载index.html前会先加载这个脚本

其它文件应该一看就懂

运行效果

总结

到此你就,正确地第一个有界面的实例运行起来了。

本示例是在windows下完成,electron在mac、linux下也可以运行,大同小异。

问题解答

  • 运行出错 try installing again
    Error: Electron failed to install correctly, please delete node_modules/electron and try installing again
    请手删除node_modules/electron并重新运行 cnpm i
相关推荐
❆VE❆7 分钟前
React基础篇(三):项目中 React 基础核心知识点实战
前端·javascript·react.js·前端框架
Hello--_--World9 分钟前
React 的核心设计理念是什么?并列举三大核心特性。
javascript·react.js·ecmascript
Momo__10 分钟前
contenteditable 深度剖析:让网页元素「活」起来
前端·html
淸湫10 分钟前
前端JavaScript:NaN、undefined、null详解
javascript
栀栀栀栀栀栀13 分钟前
强迫症犯了(゚∀゚) 2026/4/26
前端·javascript·vue.js
RPGMZ15 分钟前
RPGMakerMZ 获取敌人攻击时属性 用于画UI或属性克制
javascript·游戏引擎·rpgmz·rpgmakermz
Lucas_coding27 分钟前
【xiaozhi-客户端】xiaozhi-web-client 连接客户端 6位有效码
前端
谪星·阿凯29 分钟前
电商系统Web渗透测试实战指南
前端·网络·安全·web安全·网络安全
redreamSo37 分钟前
HeyGen 开源了一个"用 HTML 写视频"的框架,我研究了一下,发现事情没那么简单
前端·开源·音视频开发
GISer_Jing42 分钟前
前端视角:AI正在重构B端产品,传统配置化开发终将被取代?
前端·人工智能