gpt4 book ai didi

javascript - Electron 、 react 和包裹应用

转载 作者:行者123 更新时间:2023-12-03 12:40:17 25 4
gpt4 key购买 nike

我目前正在尝试将我的 Electron 应用程序编译为 mac 的 dist。我正在使用此处找到的样板文件 https://github.com/kumarryogeshh/electron-react-parcel-boilerplate

目前正在尝试模块化部分代码,特别是查看事物的 Electron 方面。因此,意图是具有以下结构。

- src 
- components
- electron_components
window.js
electron.js
App.js
custom.css
index.js

我的应用程序将有多个窗口,因此具有 windows.js类是有道理的,见下文:
const electron = require('electron');
const { BrowserWindow } = electron;
const isDev = require("electron-is-dev");

class Window extends BrowserWindow {
constructor(urldev, urlLive, height, width, resizable = true, parent = null, modal = false) {
super({
height: height,
width: width,
frame: true,
resizable: resizable,
show: true,
parent: parent,
modal: modal,
webPreferences: {
//allows application to run in the background
backgroundThrottling: true,
nodeIntegration: true
}
});
let promise = this.loadURL(
isDev
? urldev
: `file://${path.join(__dirname, urlLive)}`
);
}
}

module.exports = Window;


electron.js文件如下:
const electron = require("electron");
const app = electron.app;

const path = require("path");
const window = require(path.join(__dirname, './electron_components/window'))

let mainWindow;

function createWindow() {
mainWindow = new window('http://localhost:3000', "./build/index.html", 800, 600)
mainWindow.on("closed", () => (mainWindow = null));
}

app.on("ready", createWindow);

app.on("window-all-closed", () => {
if (process.platform !== "darwin") {
app.quit();
}
});

app.on("activate", () => {
if (mainWindow === null) {
createWindow();
}
});


所以当我通过命令 yarn start 运行应用程序时它运行并工作。这是因为它是开发环境。但是,当我构建 dist 时,通过运行 yarn build它出现以下错误:
Uncaught Exception:
Error: Cannot find module '/Volumes/electron-react-parcel 1.0.0 1/electron-react-parcel.app/Contents/Resources/app.asar/src/electron_components/window'
Require stack:
- /Volumes/electron-react-parcel 1.0.0 1/electron-react-parcel.app/Contents/Resources/app.asar/src/electron.js
-
at Module._resolveFilename (internal/modules/cjs/loader.js:797:17)
at Function../lib/common/reset-search-paths.ts.Module._resolveFilename (electron/js2c/browser_init.js:7736:16)
at Module._load (internal/modules/cjs/loader.js:690:27)
at Module._load (electron/js2c/asar.js:738:28)
at Function.Module._load (electron/js2c/asar.js:738:28)
at Module.require (internal/modules/cjs/loader.js:852:19)
at require (internal/modules/cjs/helpers.js:74:18)
at Object.<anonymous> (/Volumes/electron-react-parcel 1.0.0 1/electron-react-parcel.app/Contents/Resources/app.asar/src/electron.js:5:16)
at Module._compile (internal/modules/cjs/loader.js:967:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:1004:10)

显然,组件导入出现了问题,因此可以安全地假设 window class 的导入语句在 electron.js 的顶部文件不对。我不确定我哪里出错了,但你的帮助会很棒。

谢谢

最佳答案

因此,我选择更改为使用 Electron 锻造的不同样板。虽然没有回答原来的问题。它纠正了我的问题。

关于javascript - Electron 、 react 和包裹应用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62053389/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com