Electron中require报错的解决与分析

环境:Electron 7

使用 Create-React-App 模板

运行时发生的错误:

TypeError: fs.existsSync is not a function

  • 发生错误的代码(在 render 进程中):
const {desktopCapturer} = require('electron')
  • 处理方法:
const {desktopCapturer} = window.require('electron')

在 Electron 的 Issue #7300 中找到了解决方案,作为一名 Electron 以及 Web 前端的初学者,自然要在此问题上稍加分析,争取多了解一些背景知识,提高学习质量。

  • 此问题出现的原因为:nodejs 运行时的 require 与编译时 webpack 的 require 是不同的。默认情况下,window 是全局的,然而在 webpack 编译时会忽略 window 
  • 其他的解决方案:使用 preload 方法
  mainWindow = new BrowserWindow({
    width: 800, 
    height: 600,
    webPreferences: {
      nodeIntegration: false,
      preload: __dirname + '/preload.js'
    }
  });

在 preload.js 文件中将要使用的模块引入即可

window.ipcRenderer = require('electron').ipcRenderer;

猜你喜欢

转载自www.cnblogs.com/cdyang/p/electron-require-error.html