我正在尝试使用 React 创建 Electron 应用程序。我使用 Webpack 来编译 React JSX 语法,但是当我尝试使用webpack
命令编译时,我收到了这个错误:
> ./app.jsx中的错误 找不到模块:错误:无法解析/ Users / masterT / Downloads / gist中的模块'electron'@ ./app.jsx 6:18-37
我做错了什么?
谢谢!
答案 0 :(得分:33)
一个非常简单的解决方案:
const remote = window.require('electron').remote;
webpack将忽略此要求
答案 1 :(得分:25)
Webpack尝试使用已安装的node_modules解析electron
模块。但electron
模块在运行时在Electron本身中解析。因此,您必须从webpack捆绑中排除特定模块,如下所示:
webpack.config.js:
module.exports = {
entry: './app.jsx',
output: {
path: './built',
filename: 'app.js'
},
target: 'atom',
module: {
loaders: [
{
loader: 'babel',
test: /\.jsx$/,
query: {
presets: ['es2015', 'react']
}
}
]
},
externals: [
(function () {
var IGNORES = [
'electron'
];
return function (context, request, callback) {
if (IGNORES.indexOf(request) >= 0) {
return callback(null, "require('" + request + "')");
}
return callback();
};
})()
]
};
答案 2 :(得分:21)
您可以在网络包配置中设置target: 'electron'
,然后您不必在外部排除电子。
"electron"
在Electron中编译使用 - 支持require
- 电子专用模块。
答案 3 :(得分:0)
此外,webpack.config.js
:
const nodeExternals = require('webpack-node-externals')
module.exports = {
...
externals: [ nodeExternals(), 'react', 'electron' ],
...
}
答案 4 :(得分:-2)
您的package.json已预先制作电子版'但是你需要电子'在你的代码中。您是否尝试过要求电子预制'?