2

我在他们的网站/文档中的任何地方都找不到关于此的参考。我需要将其更改为另一个端口,目前它卡在 3000 中。

这是我创建电子项目的方法electron-forge

yarn create electron-app my-new-app --template=typescript

并且每当端口 3000 中有另一个服务时。它会抛出一个错误:

listen EADDRINUSE :::3000
Error: listen EADDRINUSE :::3000
    at Server.setupListenHandle [as _listen2] (net.js:1360:14)

我的webpack.main.config.js文件:

const path = require('path');
module.exports = {
  entry: './src/index.ts',
  // Put your normal webpack config below here
  module: {
    rules: require('./webpack.rules')
  },
  resolve: {
    extensions: ['.js', '.ts', '.jsx', '.tsx', '.css', '.json']
  },
  devServer: {
    contentBase: path.join(__dirname, 'dist'),
    compress: true,
    port: 9000
  }
};
4

3 回答 3

7

我刚开始使用 electron-forge 并遇到了同样的问题,似乎 electron/webpack 忽略了我的devServer.port价值。

在找到电子锻造配置的这个文档后,我意识到devServer.port它可能被电子锻造覆盖,并且配置的值是在 package.json 中设置的。这是我的:

{
  "name": "my-project",
  // ...
  "config": {
    "forge": {
      "packagerConfig": {},
      "makers": [
        // ...
      ],
      "plugins": [
        [
          "@electron-forge/plugin-webpack",
          {
            "mainConfig": "./webpack.main.config.js",
            "renderer": {
              "config": "./webpack.renderer.config.js",
              "entryPoints": [
                {
                  "html": "./src/index.html",
                  "js": "./src/renderer.js",
                  "name": "main_window"
                }
              ]
            },

            // the secret sauce:
            "port": 3001,
            "loggerPort": 9001
          }
        ]
      ]
    }
  }
}
于 2020-04-10T22:30:18.910 回答
0

作为对这个问题的更新,我无法复制最受好评的答案,并最终通过在另一篇文章中实现此答案,以稍微不同的方法更改了默认端口。

使用 webpack devServer 进行电子锻造

于 2022-02-02T20:05:12.327 回答
0

按照此处的说明为您的项目设置 Webpack 配置(如果尚未完成):https ://www.electronforge.io/config/plugins/webpack

然后,按照此处的说明更改devServer.port选项:https ://webpack.js.org/configuration/dev-server/

于 2020-03-02T14:54:18.487 回答