1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Electron + React 跨平台桌面应用部署及发布

Electron + React 跨平台桌面应用部署及发布

时间:2024-08-11 23:07:32

相关推荐

Electron + React 跨平台桌面应用部署及发布

概述

笔者目前在使用Electron开发跨平台桌面应用,基于原生的GUI库的支持有限,需要使用React辅助开发,之前未开发过前端项目,这次踩的坑也很多,现将对应部署过程记录,以供后来才考。

开发环境

笔者通常在MacOS/Windows上同步验证:

React环境部署及应用测试

facebook提供了 create-react-app(github地址) 用于快捷部署react开发环境,使用 npx指令(需要npm 5.2+及更高版本)即可快速部署:

npx create-react-app my-appcd my-appnpm start

主要输出内容如下:

Creating a new React app in

/XXXX/my-app.

Installing packages. This might take a couple of minutes. Installing

react, react-dom, and react-scripts…

yarn add v1.9.4 info No lockfile found. [1/4] ?

Resolving packages… [2/4] ?

Fetching packages… [3/4] ? Linking dependencies…

[4/4] ? Building fresh packages… success Saved

lockfile. success Saved 765 new dependencies. info Direct dependencies

├─ react-dom@16.4.2 ├─ react-scripts@1.1.5 └─ react@16.4.2 info All

dependencies ✨ Done in 36.93s.

Success! Created my-app at

/XXXX/my-app Inside that directory,

you can run several commands:

yarn start

Starts the development server.

yarn build

Bundles the app into static files for production.

yarn test

Starts the test runner.

yarn eject

Removes this tool and copies build dependencies, configuration files

and scripts into the app directory. If you do this, you can’t go back!

We suggest that you begin by typing:

cd my-app yarn start

Happy hacking!

生成的代码目录如下:

按照提示,执行yarn-start,输出如下:

Compiled successfully!

You can now view my-app in the browser.

Local: http://localhost:3000/ On Your Network:

http://10.10.20.77:3000/

Note that the development build is not optimized. To create a

production build, use yarn build.

浏览器中自动打开如下页面:

当需要发布应用时,需要运行npm run build生成build目录:

my-app@0.1.0 build /XXXX/my-app

react-scripts build

Creating an optimized production build… Compiled successfully.

File sizes after gzip:

36.94 KB build/static/js/main.a285be49.js 299 B build/static/css/main.c17080f1.css

The project was built assuming it is hosted at the server root. You

can control this with the homepage field in your package.json. For

example, add this to build it for GitHub Pages:

“homepage” : “http://myname.github.io/myapp“,

The build folder is ready to be deployed. You may serve it with a

static server:

yarn global add serve serve -s build

Find out more about deployment here:

http://bit.ly/2vY88Kr

目录内容如下:

该发布是为了后续打包成桌面应用使用,本文旨在描述Electron的使用,将在后面章节描述对应使用。

Electron环境部署及应用测试

在my-app下安装electron模块:

npm install -save electron

在my-app目录下创建main.js入口文件,对应代码参考React + Electron 搭建一个桌面应用 :

// 引入electron并创建一个Browserwindowconst {app, BrowserWindow} = require('electron')const path = require('path')const url = require('url')// 保持window对象的全局引用,避免JavaScript对象被垃圾回收时,窗口被自动关闭.let mainWindowfunction createWindow () {//创建浏览器窗口,宽高自定义具体大小你开心就好mainWindow = new BrowserWindow({width: 800, height: 600})/* * 加载应用----- electron-quick-start中默认的加载入口mainWindow.loadURL(url.format({pathname: path.join(__dirname, 'index.html'),protocol: 'file:',slashes: true}))*/// 加载应用----适用于 react 项目mainWindow.loadURL('http://localhost:3000/');// 打开开发者工具,默认不打开// mainWindow.webContents.openDevTools()// 关闭window时触发下列事件.mainWindow.on('closed', function () {mainWindow = null})}// 当 Electron 完成初始化并准备创建浏览器窗口时调用此方法app.on('ready', createWindow)// 所有窗口关闭时退出应用.app.on('window-all-closed', function () {// macOS中除非用户按下 `Cmd + Q` 显式退出,否则应用与菜单栏始终处于活动状态.if (process.platform !== 'darwin') {app.quit()}})app.on('activate', function () {// macOS中点击Dock图标时没有已打开的其余应用窗口时,则通常在应用中重建一个窗口if (mainWindow === null) {createWindow()}})// 你可以在这个脚本中续写或者使用require引入独立的js文件.

package.json文件中添加两个配置属性:

"main": "main.js","homepage": ".",

启动应用注意点

1、需要使用npm start先行开启react服务,使用命令后,如浏览器自动跳转,则会进入http://localhost:3000/页面。

2、然后使用electron .运行Electron应用(也可以在package.json中配置electron的运行脚本,但实际还是调用electron .指令。

另一种直接启动应用的方式

1、使用npm run build指令,生成(更新)build目录文件。

2、将 main.js 中的mainWindow.loadURL(‘http://localhost:3000/‘); 修改为

mainWindow.loadURL(url.format({pathname: path.join(__dirname, './build/index.html'),protocol: 'file:',slashes: true}));

上述./build/index.html即为使用npm run build之后的页面索引路径。

3、直接运行electron .指令。

第二种方式将会在后续打包Electron中使用。

Electron应用打包

正如React + Electron 搭建一个桌面应用中描述的:

默认情况下,homepage 是 http://localhost:3000,build 后,所有资源文件路径都是 /static,而

Electron 调用的入口是 file :协议,/static 就会定位到根目录去,所以找不到静态文件。在 package.json

文件中添加 homepage 字段并设置为”.”后,静态文件的路径就变成了相对路径,就能正确地找到了添加如下配置:

“homepage”:”.”

上一节中讲到的第二种执行方式,理论上需要每次修改之后都执行一遍npm run build才能得到正确的结果。

打包工具electron-packager的一般语法为:

electron-packager <应用目录> <应用名称> <打包平台> –out <输出目录> <架构> <应用版本>

my-app项目,在my-app目录下,输入如下:

electron-packager . my-app –darwin –out out_dir –arch=x64 –electron-version=2.0.8

输出结果如下:

Packaging app for platform darwin x64 using electron v2.0.8 WARNING:

Found ‘electron’ but not as a devDependency, pruning anyway Wrote new

app to out_dir/my-app-darwin-x64

上述指定Mac平台为–darwin,64位指定–arch=x64即可。

生成了一个out_dir/my-app-darwin-x64目录。

运行对应的my-app.app

成功!

最后说一下简单说一下electron-builder的使用,可以用来生成安装文件(或压缩文件),,参考脚本:

"scripts": {"electron-start": "electron .","react-start": "react-scripts start","react-build": "react-scripts build","react-test": "react-scripts test --env=jsdom","react-eject": "react-scripts eject","electron-build": "electron-builder","release": "yarn react-build && electron-builder --publish=always","build": "yarn react-build && yarn electron-build","start": "concurrently \"cross-env BROWSER=none yarn react-start\" \"wait-on http://localhost:3000 && electron .\""}

在上述脚本的基础上,命令行直接运行yarn build即可生成安装文件(打包的程序体积真心大……)。此外,使用yarn start即可一次性运行 Electron应用,无需分开执行react 与 electron。

需要注意的是,如果需要使用electron-builder打包应用,则原先的程序入口文件,必须放在public/目录下,且必须命名为electron.js。

笔者从报错信息得知,不清楚是否有其他方式可以避开这种固定限制。

Github源码

本文所有代码可参考 Github-electron-deploy-app 。

参考链接

facebook/create-react-appkitze/react-electron-exampleElectron 开发桌面应用(一) 编写→运行→打包React + Electron 搭建一个桌面应用How to Start Building Desktop Apps with Electron and ReactTakeaways on Building a React-Based App With ElectronCREATE AN APP WITH ELECTRON AND REACTelectron-userland/electron-packager

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。