【发布时间】:2017-08-03 11:51:33
【问题描述】:
我在尝试将这两件事粘合在一起时遇到了一些问题。
让我给你一些背景信息:我正在尝试基于我在 react 中开发的 web 应用程序构建一个桌面应用程序,它完全可以运行,并且 react 的构建过程没有任何错误或问题。当我尝试将 Electron + React Built Project 粘合在一起时,问题就来了。
我的结构如下:
- /dist
- /node_modules
- /react-mobx-router
- /构建
- /静态
- /js
- main.05ef4655.js
- /css
- main.9d8efafe.css
- /js
- index.html
- /静态
- /构建
- index.js
在 index.js 我有以下代码,基本上是来自电子演示应用程序的示例样板代码:
'use strict';
const electron = require('electron');
const app = electron.app;
// adds debug features like hotkeys for triggering dev tools and reload
require('electron-debug')();
// prevent window being garbage collected
let mainWindow;
function onClosed() {
// dereference the window
// for multiple windows store them in an array
mainWindow = null;
}
function createMainWindow() {
const win = new electron.BrowserWindow({
width: 1280,
height: 720,
minWidth: 1280,
minHeight: 720
});
win.loadURL(`file://${__dirname}/react-mobx-router/build/index.html`);
//win.loadURL(`http://localhost:3000`);
win.on('closed', onClosed);
return win;
}
app.on('window-all-closed', () => {
if (process.platform !== 'darwin') {
app.quit();
}
});
app.on('activate', () => {
if (!mainWindow) {
mainWindow = createMainWindow();
}
});
app.on('ready', () => {
mainWindow = createMainWindow();
});
我还必须在 react 构建的 index.html 中手动更改一些路径,使其看起来像:
<link href="./static/css/main.9d8efafe.css" rel="stylesheet">
代替:
<link href="/static/css/main.9d8efafe.css" rel="stylesheet">
第二个得到以下错误:
file:///D:/static/css/main.9d8efafe.css Failed to load resource: net::ERR_FILE_NOT_FOUND
main.05ef4655.js Failed to load resource: net::ERR_FILE_NOT_FOUND
关键是,当我使用 yarn start 启动 Electron 应用程序时(更改我之前告诉过你的路径)它启动时没有任何错误或问题,但只有一个空白屏幕,如果我转到文件并查看对他们来说,它们是正确的,代码在里面,捆绑在一起,所有 react-create-app 的东西都可以。
这是Electron自带的package.json的默认配置,我没有修改:
{
"name": "app",
"productName": "App",
"version": "0.0.0",
"description": "",
"license": "MIT",
"repository": "user/repo",
"author": {
"name": "",
"email": "",
"url": ""
},
"scripts": {
"test": "xo",
"start": "electron .",
"build": "electron-packager . --out=dist --asar --overwrite --all"
},
"files": [
"index.js",
"index.html",
"index.css"
],
"keywords": [
"electron-app",
"electron"
],
"dependencies": {
"electron-debug": "^1.0.0"
},
"devDependencies": {
"devtron": "^1.1.0",
"electron-packager": "^8.0.0",
"electron": "^1.0.1",
"xo": "^0.16.0"
},
"xo": {
"esnext": true,
"envs": [
"node",
"browser"
]
}
}
这也是我的 React 项目的 package.json:
{
"name": "react-mobx",
"version": "0.1.0",
"private": true,
"devDependencies": {
"custom-react-scripts": "0.0.23",
"mobx-react-devtools": "^4.2.11"
},
"dependencies": {
"mobx": "^3.1.4",
"mobx-react": "^4.1.2",
"mobx-react-router": "latest",
"react": "^15.4.2",
"react-dom": "^15.4.2",
"react-router": "latest"
},
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test --env=jsdom",
"eject": "react-scripts eject"
}
}
请注意,如果我不使用 Electron,React 应用程序是完全可用的。
这就是为什么我请求你的智慧,伙计们。我需要一些亮光,这样我才能继续这个项目。希望你能帮助我解决这个问题,我已经为你提供了足够的信息。如果您需要更多信息,请告诉我。
热烈的问候, 亚历克斯。
【问题讨论】:
标签: javascript reactjs electron