Skip to content

Latest commit

 

History

History
330 lines (154 loc) · 7.32 KB

Electron基础入门.md

File metadata and controls

330 lines (154 loc) · 7.32 KB

Electron基础入门

Electron 简介

Electron 是 Github 开源的跨平台桌面应用开发工具,使用 Web 技术( HTML5 + JS + CSS3) 开发桌面应用。

  1. Electron 本身是基于 C++ 开发的
  2. GUI 核心是 Chrome
  3. JS 引擎是 V8 (Nodejs)

Electron优点:学习成本、开发成本低——只需要会传统的 Web 开发即可。

Electron缺点:安装文件大、执行效率相对原生程序效率低

Electron 官网:https://www.electronjs.org/


Chromium VS Chrome

一定要记住 electron 内嵌的是 Chromium 内核,而不是 谷歌浏览器 Chrome!

所以当你在运行 electron 应用时如果出现了某些异常,即 直接使用浏览器访问没有问题但是在 electron 应用中有问题的,要考虑排查一下是不是因为 Chromium 与 Chrome 差异的原因。


常见的一个差异是:Chromium 只支持 H.246 格式的 mp4 文件,而 Chrome 确支持更多格式的 mp4 格式文件。

实际的表现为 electron 应用运行包含视频的网页时,如果 mp4 格式非 H.246 编码,那么可能会出现视频只显示进度条但没有画面内容的情况。


快速创建Electron项目

下面执行命令中使用 yarn,如果你使用 npm 请将命令替换为 npm 对应命令

可以使用官方提供的模板:

git clone https://github.com/electron/electron-quick-start
cd electron-quick-start
yarn install
yarn start

Electron 官方提供了好几个不同框架或库的继承模板:

使用 TypeScript:

git clone https://github.com/electron/electron-quick-start-typescript

使用 Vue:

npm install -g vue-cli
vue init simulatedgreg/electron-vue my-project

cd my-project
yarn # or npm install
yarn run dev # or npm run dev

使用React:

git clone --depth 1 --single-branch https://github.com/electron-react-boilerplate/electron-react-boilerplate.git your-project-name

注意:该模板中使用的 react 版本为 16.8,并且不自带 TypeScript


更多工具和模板:

https://github.com/sindresorhus/awesome-electron


运行Electron

假设我们希望使用 Electron 运行某个 js 文件,命令为:

electron xxx.js

解决中文字符串乱码问题

假设我们在 xxx.js 中添加有输出 console.log(xxx)。

如果输出内容中有中文,由于 windows 的 CMD 环境中 默认编码为 936(GBK编码),而我们的 xxx.js 中采用的是 65001(UTF-8) 编码。

所以我们需要先将当前命令环境的编码进行修改:

chcp 65001

这样再去执行 electron xxx.js 中文就不会出现乱码了。


为了方便,我们可以直接给 package.json 中添加命令:

"scripts": {
    "electron": "chcp 65001 && electron xxx.js"
}

补充:查看当前 CMD 环境中的字符编码命令为:

chcp

Electron帮助文档

详细的 API 和官方使用指南,请查阅:

https://www.electronjs.org/docs


Electron代码提示

由于 electron NPM 包中自带 electron.d.ts,所以只要执行:yarn add --dev electron 即可获取 typescript 代码提示。

特别说明:由于安装命令中包含 --dev 参数,所以正式构建项目代码时 electron NPM 包中的代码并不会被打包进去。


Electron安装失败的解决方式

在执行 yarn add --dev [email protected] 时,可能会遇到下面报错信息:

Output:
RequestError: connect ETIMEDOUT
...

这是因为 electron 那个 壳(二进制运行文件) 没有下载成功。


你可以尝试将 npm 源修改为 国内的淘宝 npm。


-------- 以下更新于 2024.12.07 --------

直接在项目根目录下新建 .npmrc 文件:

registry=https://registry.npmmirror.com/
electron_mirror=https://registry.npmmirror.com/-/binary/electron/

一定要重启 VSCode !

然后再次安装就应该可以了。

-------- 以上更新于 2024.12.07 --------


以下这种 手工安装方式 已经不推荐了!!!

我教大家一个 “手工安装” 的方式,来解决这个问题。


纯手工安装electron的步骤:

这里我们假定要安装的是 64 位操作系统下的 electron 13.0.0

  1. 先按照正常流程安装:yarn add --dev [email protected]

    当执行若干秒后,会收到刚才提到的报错 RequestError: connect ETIMEDOUT,但是请注意,此时 node_modules/electron 中是有内容的。

  2. 访问 https://github.com/electron/electron/releases/tag/v13.0.0 ,找到 electron-v13.0.0-win32-x64.zip 并下载该文件

  3. 将手工下载得到的 electron-v13.0.0-win32-x64.zip 文件拷贝到 node_modules/electron 中

  4. 编辑 node_modules/electron/install.js 文件,将其中 downloadArtifact 相关代码都注释掉,因为此时我们不需要走下载流程了

  5. 同时找到 extractFile 这个函数,在它下面添加一行代码:extractFile('./electron-v13.0.0-win32-x64.zip')

  6. 在命令窗口,切换到 node_modules/electron 中,然后执行:node install.js

    注意:当执行完该命令后,并不会有任何信息输出

  7. 至此,就完成了手工安装 electron 了


但是,上面那种操作会有一个潜在问题:

当执行 asar pack ... 去打包项目时,会将 node_modules/electron 这个目录也一并打包进去,造成文件体积增大 180M 左右。

解决方式为:通过给 asar pack 添加 --unpack-dir 参数来忽略这个目录,同时还需要将额外产生的 app.asar.unpacked 目录删除。

asar pack . app.asar --unpack-dir "node_modules/electron" && rd /s/q "app.asar.unpacked"

假设你是在 package.json 的 scripts 中添加上述命令,一定要将上面命令中的每一个引号 " 前面增加一个斜杠 \

{
    "scripts": {
        "asar":"asar pack . app.asar --unpack-dir \"node_modules/electron\" && rd /s/q \"app.asar.unpacked\""
    }
}

如何参与翻译Electron中文文档?

Electron 的官方简体中文文档地址为:https://www.electronjs.org/zh/docs/latest/

假设你发现某些简体中文文档有错误、歧义、未翻译的地方,如果你也想贡献自己的翻译,那么 Electron 提供了以下 2 种途径。


第1种:向 electron/i18n 仓库提交合并申请

electron/i18n 仓库地址:https://github.com/electron/i18n/tree/master/content/zh-CN

补充说明: i18n 实际上是单词 internationalization(国际化) 的一种特殊简写,即 开头字母 i + 中间18个字母 + 结尾字母n


第2种:通过 crowdin.com 提交自己的翻译

crowdin.com 是一个专门用于大型、多人在线翻译的平台。

其中 Electron 项目翻译地址为: https://crowdin.com/project/electron/zh-CN#/docs/latest/tutorial

你可以注册一个账户,然后参与其中。


补充:

Electron 项目的仓库地址:https://github.com/electron/electron/ 中,只接受英文文档的合并申请。