Webpack版本5.1.2错误“ MainTemplate.hooks.startup已被删除”

时间:2020-10-16 03:50:06

标签: javascript node.js reactjs webpack babeljs

我在教程中观看的ReactJS + Webpack + Express遇到问题。 完成设置以下文件后:

  • server.js
  • webpack.config.js
  • .babelrc
  • package.json

尝试在VS Code bash终端中运行服务器之后。我得到以下输出:

Error: MainTemplate.hooks.startup has been removed (use RuntimeGlobals.startup instead) at Object.tap

这是上面所有文件的代码

server.js:

    import express from 'express';
    import webpack from 'webpack';
    import WebpackDevMiddleware from 'webpack-dev-middleware';
    import webpackConfig from '../webpack.config';

    // init packages
    const app = express();

    // set server
    app.set('port', process.env.PORT || 8080);

    // middleware
    app.use(WebpackDevMiddleware(webpack(webpackConfig)));

    // routes
    app.get('/', (request, response) => {
        response.send('Hello, user');
    });

    app.get('/demo', (request, response) => {
        response.json({demo: 'Hello, demo user' });
    });

    // listen on port
    app.listen(app.get('port'), () => {
        console.log('server on port ', app.get('port'));
    });

webpack.config.js:

    import webpack from 'webpack';
    import htmlWebpackPlugin from 'html-webpack-plugin';
    import LiveReloadPlugin from 'webpack-livereload-plugin';

    export default {
        entry: './src/client/index.js',
        output: {
            path: '/',
            filename: 'bundle.js'
        },
        module: {
            rules: [
                {
                    use: 'babel-loader',
                    test: /\.js$/,
                    exclude: /node_modules/
                },
                {
                    use: ['style-loader', 'css-loader'],
                    test: /\.css$/
                },
                {
                    test: /\.scss$/,
                    use: [
                        { loader: 'style-loader' },
                        {
                            loader: 'css-loader',
                            options: { sourceMap: true }
                        },
                        {
                            loader: 'sass-loader',
                            options: { sourceMap: true }
                        }
                    ]
                }
            ]
        },
        plugins: [
            new htmlWebpackPlugin({ template: './src/client/index.html' }),
            new LiveReloadPlugin()
        ],
    }

.babelrc:

    {
        "presets": [ "env", "react" ]
    }

package.json:

    {
      "name": "nodejs-practice",
      "version": "1.0.0",
      "description": "NodeJS Practice with React, MongoDB and NodeJS",
      "main": "main.js",
      "scripts": {
        "dev": "nodemon --exec babel-node src/server.js",
        "test": "echo \"Error: no test specified\" && exit 1"
      },
      "keywords": [],
      "author": "",
      "license": "ISC",
      "devDependencies": {
          "babel-cli": "^6.26.0",
          "babel-core": "^6.26.3",
          "babel-loader": "^8.1.0",
          "babel-preset-env": "^1.7.0",
          "babel-preset-react": "^6.24.1",
          "css-loader": "^5.0.0",
          "html-webpack-plugin": "^4.5.0",
          "node-sass": "^4.14.1",
          "nodemon": "^2.0.5",
          "sass-loader": "^10.0.3",
          "style-loader": "^2.0.0",
          "webpack": "^5.1.2",
          "webpack-dev-middleware": "^3.7.2",
          "webpack-livereload-plugin": "^2.3.0"
      },
      "dependencies": {
          "express": "^4.17.1",
          "react": "^16.14.0",
          "react-dom": "^16.14.0"
      }
    }

我想知道问题出在哪里,因为我一直在寻找一些答案,但找不到任何东西。 我认为我可能必须降级几个依赖项。

谢谢。

1 个答案:

答案 0 :(得分:1)

这是因为webpack-livereload-plugin使用的Webpack API无效

这是issue的跟踪解决方法