我刚开始从电子文档学电子。我用ES6 (import/export)
,他们用require
。
我在我的package.json
中添加了package.json
,也将js
扩展更改为mjs
,但是每次运行npm start
(节点版本=> 14 )时,我都会得到以下错误:
App threw an error during load
Error [ERR_REQUIRE_ESM]: Must use import to load ES Module: /Users/alaeddine/Desktop/electron-app/petro-book/main.mjs
at Module.load (internal/modules/cjs/loader.js:933:11)
at Module._load (internal/modules/cjs/loader.js:776:14)
at Function.f._load (electron/js2c/asar_bundle.js:5:12684)
at loadApplicationPackage (/Users/alaeddine/Desktop/electron-app/petro-book/node_modules/electron/dist/Electron.app/Contents/Resources/default_app.asar/main.js:110:16)
at Object.<anonymous> (/Users/alaeddine/Desktop/electron-app/petro-book/node_modules/electron/dist/Electron.app/Contents/Resources/default_app.asar/main.js:222:9)
at Module._compile (internal/modules/cjs/loader.js:1078:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:1108:10)
at Module.load (internal/modules/cjs/loader.js:935:32)
at Module._load (internal/modules/cjs/loader.js:776:14)
at Function.f._load (electron/js2c/asar_bundle.js:5:12684)
Package.json:
{
"type": "module",
"name": "petro-book",
"version": "0.1.0",
"author": "Menai Ala Eddine",
"description": "Desktop application for gas stations",
"main": "main.mjs",
"scripts": {
"start": "electron main.mjs"
},
"devDependencies": {
"electron": "^12.0.7"
}
}
Main.mjs:
import { app, BrowserWindow } from "electron";
import { join } from "path";
function createWindow() {
const win = new BrowserWindow({
width: 800,
height: 600,
webPreferences: {
preload: join(__dirname, "preload.js"),
},
});
win.loadFile("index.html");
}
app.whenReady().then(() => {
createWindow();
app.on("activate", () => {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow();
}
});
});
app.on("window-all-closed", () => {
if (process.platform !== "darwin") {
app.quit();
}
});
preload.js
window.addEventListener("DOMContentLoaded", () => {
const replaceText = (selector, text) => {
const element = document.getElementById(selector);
if (element) element.innerText = text;
};
for (const type of ["chrome", "node", "electron"]) {
replaceText(`${type}-version`, process.versions[type]);
}
});
发布于 2022-07-12 20:08:35
首先,您必须在node_modules中加载esm。
$ npm安装esm --保存
在配置中放入下面的配置。我的情况是:
"main": "src/index.cjs",
"module" : "src/main.mjs",
"type": "module",
将主脚本放在main.mjs中打开窗口(使用es6样式)。
这里是index.cjs作为启动:
require = require("esm")(module/* , options */)
module.exports = require("./main.mjs")
以及我们在main.mjs中的主要角色
import electron from 'electron';
import path from 'path';
const app = electron.app;
const BrowserWindow = electron.BrowserWindow;
function createWindow() {
....
}
在这里登记https://arahutara.wordpress.com/2022/07/13/using-es6-import-in-electron-apps/
希望这能帮上忙。
发布于 2021-05-08 03:29:59
import
仅用于ES6模块,仅在NodeJS中使用
const { app, BrowserWindow } = require("electron");
const join = require("path").join;
function createWindow() {
const win = new BrowserWindow({
width: 800,
height: 600,
webPreferences: {
preload: join(__dirname, "preload.js"),
},
});
win.loadFile("index.html");
}
app.whenReady().then(() => {
createWindow();
app.on("activate", () => {
if (BrowserWindow.getAllWindows().length === 0) {
createWindow();
}
});
});
app.on("window-all-closed", () => {
if (process.platform !== "darwin") {
app.quit();
}
});
以上内容在电子文档中得到推荐和说明。
https://stackoverflow.com/questions/67443778
复制相似问题