我是 JavaScript 和 Electron 的完全初学者,所以你知道。
我想我已经找遍了大多数地方,但没有找到任何东西。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>??</title>
<link rel="stylesheet" href="style.css">
</head>
<body>
<div class="main">
<button id="get-data" type="submit">Get Data</button>
</div>
<script src="script.js"></script>
</body>
</html>
const { app, BrowserWindow } = require("electron");
const ipc = require("electron").ipcMain;
app.whenReady().then(() => {
const window = new BrowserWindow({
"center": true,
"width": 500,
"height": 800,
"webPreferences": {
"nodeIntegration": true
}
});
window.loadFile("index.html");
});
ipc.on("uhhm", event => {
event.sender.send("ok", "Hello World!");
});
const ipc = require("electron").ipcRenderer;
const getDataBtn = document.getElementById("get-data");
getDataBtn.addEventListener("click", () => {
ipc.send("uhhm");
ipc.once("ok", data => {
getDataBtn.innerHTML = "Moving On... " + data;
});
});
Uncaught ReferenceError: require is not defined
at script.js:1
IDK 做什么
有什么建议吗?
答案 0 :(得分:1)
如果您使用的是 >= 5 版本的 Electron,则需要按如下方式启用 nodeIntegration 和 contextIsolation 参数:
app.on('ready', () => {
mainWindow = new BrowserWindow({
webPreferences: {
nodeIntegration: true,
contextIsolation: false,
}
});
});
答案 1 :(得分:0)
当我使用 Electron Framework 工作一段时间时遇到了这个问题,我需要在渲染器进程和主进程之间进行 IPC 通信。渲染器进程位于脚本标记之间的 HTML 文件中,并生成相同的错误。
const {ipcRenderer} = require('electron')
//throws the Uncaught ReferenceError: require is not defined
就你而言:
const ipc = require("electron").ipcRenderer;
当浏览器窗口(嵌入此 HTML 文件的位置)最初是在主进程中创建时,您必须通过将 Node.js 集成指定为 true 来解决这个问题。
function createWindow() {
// Create a new window
const window = new BrowserWindow({
width: 300,
height: 200,
// The lines below solved the issue
webPreferences: {
nodeIntegration: true
}
})}
这为我解决了这个问题。已提出解决方案 here。