webpack-dev-server开启 hot 没有效果?

发布于 2022-09-12 03:52:43 字数 1969 浏览 18 评论 0

webpack-dev-server开启 hot 没有效果, 不会自动刷新页面

具体情况:

webpack.config.js 中的 devServer 里面配置了 hottrue, 运行起来并没有刷新页面,但是实际上已经生成 .hot-update.js并且在 html 中引用了(看浏览器控制台看出来的),想知道为什么没有热更新页面。

相关代码

包版本

"clean-webpack-plugin": "^3.0.0",
"css-loader": "^3.6.0",
"file-loader": "^6.0.0",
"html-webpack-plugin": "^4.3.0",
"style-loader": "^1.2.1",
"webpack": "^4.43.0",
"webpack-cli": "^3.3.12",
"webpack-dev-server": "^3.11.0"

webpack.config.js ( 重点看 devServer 就好 ) ~~~~

const path = require('path')

const HtmlWebpackPlugin = require('html-webpack-plugin');
const {CleanWebpackPlugin} = require('clean-webpack-plugin');
const webpack = require('webpack');

module.exports = {
  entry: {
    app: './src/index.js',
  },
  output: {
    filename: "[name].bundle.js",
    path: path.resolve(__dirname, 'dist'),
  },
  plugins: [
    new HtmlWebpackPlugin({
      title: 'webpack demo',
      filename: "index.html",
      template: "src/index.html"
    }),
    new CleanWebpackPlugin({
      cleanAfterEveryBuildPatterns: ["dist"]
    }),
    new webpack.HotModuleReplacementPlugin()
  ],
  module: {
    rules: [
      {
      
        test: /\.css$/,
       
        use: ["style-loader", 'css-loader']
      }, {
        test: /\.(png|svg|jpg|gif)$/,
        use: [
          {
            loader: 'file-loader',
            options: {
              name: "[name].[ext]",
              outputPath: 'imgs/'
            }
          }
        ]
      },
      {
        test: /\.(woff|woff2|eot|ttf|oth)$/,
        use: ["file-loader"]
      }
    ]
  },
  devServer: {
    contentBase: path.join(__dirname, 'dist'), 
    port: 8000,
    openPage: 'index.html',
    open: true, 
    hot: true, 
    hotOnly: true, 
  }
};

运行的时候控制台的情况
控制台情况实例

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

沫离伤花 2022-09-19 03:52:43

// 更新
今天重新看了一下这个问题,发现不是 hotOnly 的原因,是因为没有在入口文件配置:

if (module.hot) {
    module.hot.accept('./print.js', function() {
        console.log('Accepting the updated printMe  module!');
        printMe();
    })
}   

具体文档查看:HMR
)

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文