0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

【webpack】target: electron-rendererを設定するとFormDataが使えない

Last updated at Posted at 2018-04-24

環境

webpack 3.10.0

問題

webpackの設定でtargetelectron-rendererにすると、FormDataが使えない。

const data = new FormData();
data.append(name, value) // ここでエラーになる

webpack関係ないですが、同じように困ってる人もいました。
https://github.com/form-data/form-data/issues/220

かといってtargetelectron-rendererにしないとrendererプロセスでelectronの機能が扱えない。
shell使ってデフォルトブラウザ開いたり、プロセス間通信したり。

解決策

electronの使いたい機能はバンドル対象のにせず、scriptタグでjsファイルを読み込むようにした。
webpakc.config.jstargetからelectron-rendererも削除。

index.html
<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8" />
    <title></title>
</head>

<body>
    <div id="app"></div>
    <script src="./shell.js"></script> // 今回作成したファイル
    <script src="./bundle.js"></script> // バンドルファイル
</body>

</html>
shell.js
const remote = require('electron').remote;
const shell = remote.shell;

const openDefaultBrowser = url => {
    shell.openExternal(url);
};

もっといい方法、webpackの設定での解決法を知ってる人いたら教えてください。

0
1
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?