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
相关推荐
_xaboy5 分钟前
开源Vue组件-动态表单组件设计,告别重复CRUD,JSON一键生成表单
前端·vue.js·低代码·开源·json
POLITE311 分钟前
Leetcode 236. 二叉树的最近公共祖先 (Day 17) JavaScript
linux·javascript·leetcode
Access开发易登软件12 分钟前
Access 连接 SQL Server:直通查询 vs 链接表 vs ADO,如何选择?
前端·数据库·vba·access·access开发
雨季66614 分钟前
构建 OpenHarmony 简易数字猜谜游戏:用随机与反馈打造轻量级互动体验
javascript·flutter·游戏·ui·自动化·dart
HWL567917 分钟前
Vue Router中,传递参数的几种方式
前端·javascript·vue.js
米高梅狮子22 分钟前
项目实战: LAMP-电商平台-iwebshop
前端·网络·chrome
qq_3517547823 分钟前
关于vue3切换空白页问题解决
开发语言·前端
风景的人生27 分钟前
小程序接收respose中的数组
前端·微信小程序·小程序
晚霞的不甘27 分钟前
Flutter for OpenHarmony 电商 App 搜索功能深度解析:从点击到反馈的完整实现
开发语言·前端·javascript·flutter·前端框架