【问题标题】:Electron react build not launching电子反应构建未启动
【发布时间】: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
      • 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


    【解决方案1】:

    我不是 React 英雄(很长一段时间),但我能够使用此样板文件中列出的架构运行、热重载和发布构建:electron-es6-react。我为构建添加了一些条件代码到main.js(下)。毫无疑问,有更好的解决方案。

    你肯定需要将你的 React package.json 与 Electron 合并。

    var isDev = process.env.APP_DEV ? (process.env.APP_DEV.trim() == "true") : false;
    
    if (isDev) {
      // only add this during development
      require('electron-reload')(__dirname, {
        electron: path.join(__dirname, 'node_modules', '.bin', 'electron')
      });
    }
    

    package.json

    {
      "name": "electron-es6-react",
      "version": "0.1.0",
      "description": "template",
      "license": "MIT",
      "production": false,
      "version-string": {
        "CompanyName": "Cool Co.",
        "FileDescription": "template",
        "OriginalFilename": "template",
        "ProductName": "template",
        "InternalName": "template"
      },
      "main": "main.js",
      "scripts": {
        "start": "APP_DEV=true electron -r babel-register .",
        "package-mac": "electron-packager . --overwrite --tmpdir=false --platform=darwin --arch=x64  --prune=true --out=release-builds",
        "package-win": "electron-packager . --overwrite --tmpdir=false --asar=true --platform=win32 --arch=ia32 --prune=true --out=release-builds"
      },
      "dependencies": {
        "babel-preset-es2015": "^6.3.13",
        "babel-preset-react": "^6.3.13",
        "babel-register": "^6.3.13",
        "fs-jetpack": "^0.12.0",
        "react": "^15.3.2",
        "react-dom": "^15.3.2",
        "react-images": "^0.5.2"
      },
      "devDependencies": {
        "electron": "^1.4.3",
        "electron-packager": "^8.5.2",
        "electron-reload": "^1.1.0"
      }
    }

    【讨论】:

    • Ahm ...这对我不起作用...我认为这是因为我需要在启动 Electron App 之前设置一个快速服务器来为 React App 提供服务,然后是 ser window.openUrl(' localhost:3000') 例如,为了显示 React 应用程序,我不能只在浏览器中“打开文件”一个 React 应用程序。
    • @AlexCasillas – 我在学习 React 时选择了更简单的设置来降低复杂性。还有其他设置可以完成整个服务器/本地主机的事情——electron-react-boilerplate。您仍然需要合并这些 package.json 文件。
    猜你喜欢
    • 2019-01-29
    • 1970-01-01
    • 2018-10-30
    • 2018-02-11
    • 2019-10-04
    • 2022-12-04
    • 2021-12-02
    • 1970-01-01
    相关资源
    最近更新 更多