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;

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM