如何解决将 React 与 Electron 结合使用,以便仍然可以使用 Node.js 原生模块
我正在尝试在我的 React 应用程序中使用 crypto.scrypt()
from Node.js Crypto,在 Electron v11.2.1 中运行。
目前,我使用 react-scripts start
来启动开发服务器。
然后我启动 Electron 应用程序,它在 main.js 中配置如下:
mainWindow.loadURL('http://localhost:3000');
在我的 React 应用中:
const nodeCrypto = require('crypto');
问题:如果我执行 console.log(nodeCrypto)
,对象不包含 scrypt
或 scryptSync
。
另一方面,如果我创建了一个新的简单 Electron 项目并且不使用 React,而是像这样配置它:
在 main.js 中:
mainWindow.loadFile('index.html');
在 index.html 中:
<script>
require('./renderer.js');
</script>
在 renderer.js 中:
const nodeCrypto = require('crypto');
console.log(nodeCrypto);
正如我所料,我可以在 scrypt
的控制台日志中看到 scryptSync
和 nodeCrypto
。
现在,我的理论是这样的:因为 React 应用程序在 http://localhost:3000
上“单独”运行,所以它没有使用 native Node.js module 中的 crypto
,而是从某个地方使用它别的。我可能是错的。
我的问题是...如何在开发服务器中运行 React 应用程序(以便在开发过程中实时重新加载),但仍然可以访问 Electron 内部的 Node.js 原生模块,例如 crypto
?>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。