Electron解决 require is not defined 问题

本文介绍了在Electron 16.0.7版本中遇到`require is not defined`错误的原因及解决方法,主要是通过在应用入口文件设置`nodeIntegration`为`true`和`contextIsolation`为`false`来允许使用require导入导出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

electron版本号:16.0.7

一、报错原因

JS中没有node模块,导致无法使用require导入 导出

二、解决办法

在入口文件设置两个属性

nodeIntegration:true

contextIsolation:false

// 加载page需要两个模块:app BrowserWindow
const { app, BrowserWindow } = require("electron");
const path = require("path");
// 热加载
const reloader = require("electron-reloader");
const { contextId, contextIsolated } = require("process");
reloader(module);

app.on("window-all-closed", () => {
  if (process.platform !== "darwin") app.quit();
});
app.on("ready", () => {
  const mainWindow = new BrowserWindow({
    width: 700,
    height: 700,
    frame:false,
    webPreferences:{
        //  渲染进程 开启node模块,使得JS中可以使用node的model
        nodeIntegration:true,
        // 开启 remote 模块
        enableBlinkFeatures:true,
        // 控制上下文隔离
        // contextIsolation:false,
    }
  });
  // 打开控制台
  mainWindow.webContents.openDevTools();
  // 加载页面
  mainWindow.loadFile("./src/index.html");
  
});

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值