電子アプリケーションをReactで作成しようとしています。 Webpackを使用してReact JSX構文をコンパイルしますが、 webpack
コマンドでコンパイルするには、次のエラーが表示されました。
./app.jsxモジュールのエラーが見つかりません:エラー:/ Users/masterT/Downloads/Gistのモジュール「electron」を解決できません
@ ./app.jsx 6:18-37
アプリケーションコード です。
私は何か間違っていますか?
ありがとう!
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();
};
})()
]
};
非常に簡単な解決策:
const remote = window.require('electron').remote;
webpackはこのrequireを無視します
Webpackの設定でtarget: 'electron'
を設定すれば、外部のエレクトロンを除外する必要はありません。
"electron"
Electron で使用するためにコンパイル-require
- ing Electron固有のモジュールをサポートします。