webpack热替换


安装webpack-dev-server

npm install webpack-dev-server -D

通过node脚本的方式

package.json

{
"scripts":{"start": "webpack-dev-server --config webpack.dev.js --hot --port 3000 --open"}
}

webpack.common.js

const path = require('path'),
  CleanWebpackPlugin = require('clean-webpack-plugin').CleanWebpackPlugin,
  HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
  entry: {
    app: './src/index.js'
  },
  plugins: [
    new CleanWebpackPlugin(),
    new HtmlWebpackPlugin({ title: 'production' })
  ],
  // 压缩css用的loader
  module: { rules: [{ test: /\.css$/, use: ['style-loader', 'css-loader'] }] },
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, 'dist')
  }
};

webpack.dev.js

const merge = require('webpack-merge'),
  path = require('path'),
  common = require('./webpack.common');

module.exports = merge(common, {
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, 'dist'),
    publicPath: '/'
  },
  devtool: 'inline-source-map',
  devServer: {
    contentBase: './dist/'
  }
});

通过webpack配置

devServer中增加
hot:true
webpack.dev.js

const merge = require('webpack-merge'),
  webpack = require('webpack'),
  path = require('path'),
  common = require('./webpack.common');

module.exports = merge(common, {
  output: {
    filename: '[name].bundle.js',
    path: path.resolve(__dirname, 'dist'),
    publicPath: '/'
  },
  devtool: 'inline-source-map',
  devServer: {
    contentBase: './dist/',
    hot: true
  },
  plugins: [
    // 可以显示模块的相对路径
    new webpack.NamedModulesPlugin()
  ]
});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值