React+Electron快速創(chuàng)建并打包成桌面應(yīng)用的實例代碼
一、創(chuàng)建react項目
首先使用creat-react-app腳手架來創(chuàng)建一個react項目
# 安裝 create-react-app 命令,如果已將安裝請忽略 npm install -g create-react-app # 創(chuàng)建 react項目 create-react-app react-electron # 啟動項目( create-react-app 真的超級方便啊) cd react-electron && npm start
npm start之后瀏覽器會自動打開網(wǎng)址 http://localhost:3000/ ,出現(xiàn)react項目的頁面了

二、安裝Electron
#在react-electron項目目錄下 npm install -save electron
三、配置文件
1.在項目根目錄新建main.js
const { app, BrowserWindow } = require("electron")
const path = require('path')
const url = require('url')
function createWindow() {
const win = new BrowserWindow({
width: 800,
height: 800,
minWidth: 800,
minHeight: 800
})
win.loadURL("http://localhost:3000/")
}
app.whenReady().then(() => {
createWindow()
app.on("active", () => {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow()
}
})
})
app.on("window-all-closed", () => {
if (process.platform !== "darwin") {
app.quit()
}
})2.配置package.json
添加如下兩項配置:
{
"main": "main.js", // 配置electron的啟動文件
"scripts": {
"electron-start": "electron ."
},
}3.啟動electron
# 這里要打開兩個窗口 # 啟動react項目 npm start # 啟動electron npm run electron-start
npm run electron-start之后會自動出現(xiàn)桌面應(yīng)用

四、打包Electron桌面應(yīng)用
1.安裝 electron-packager
npm install electron-packager -D
2.** 配置homePage字段**
在package.json文件中添加如下配置
{
"homepage": "."
}{
"script": {
"package": "electron-packager ./build react-electron --platform=darwin --arch=x64 --electron-version 17.1.0 --overwrite"
}
}
//mac系統(tǒng) --platform=darwin
//Windows系統(tǒng) --platform=win32然后打包react代碼,根目錄會多出一個build文件夾
npm run build
將main.js和package.json兩個文件復(fù)制到build文件夾下,同時修改build文件夾下的main.js
// 加載應(yīng)用----electron默認的打包入口
win.loadURL(url.format({
pathname: path.join(__dirname, './index.html'), // 修改這里
protocol: 'file:',
slashes: true
}))在根目錄運行打包命令
npm run package
到此這篇關(guān)于React+Electron快速創(chuàng)建并打包成桌面應(yīng)用的文章就介紹到這了,更多相關(guān)React Electron桌面應(yīng)用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
如何使用 electron-forge 搭建 React + Ts&n
本文介紹了如何使用Electron、electron-forge、webpack、TypeScript、React和SCSS等技術(shù)搭建一個桌面應(yīng)用程序,通過這篇文章,開發(fā)者可以創(chuàng)建一個包含React組件、SCSS樣式、靜態(tài)資源和Loading頁面的應(yīng)用,感興趣的朋友一起看看吧2025-01-01
React之錯誤邊界 Error Boundaries示例詳解
這篇文章主要為大家介紹了React之錯誤邊界Error Boundaries示例教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-10-10
React使用highlight.js Clipboard.js實現(xiàn)代碼高亮復(fù)制
這篇文章主要為大家介紹了React使用highlight.js Clipboard.js實現(xiàn)代碼高亮復(fù)制功能示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-04-04
一文搞懂?React?18?中的?useTransition()?與?useDeferredValue()
這篇文章主要介紹了一文搞懂?React?18?中的?useTransition()與useDeferredValue(),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-09-09
create-react-app構(gòu)建項目慢的解決方法
這篇文章主要介紹了create-react-app構(gòu)建項目慢的解決方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03
每天一個hooks學(xué)習(xí)之useUnmount
這篇文章主要為大家介紹了每天一個hooks學(xué)習(xí)之useUnmount,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05

