LiveReload when running webpack --watch
webpack-livereload-plugin plugin always sends all assets to tiny-lr plugin to trigger a reload.
This fork only sends modified files to it.
Install the package
# for webpack 4 npm install --save-dev webpack-livereload-changed-chunks-plugin # for webpack 3 npm install --save-dev webpack-livereload-changed-chunks-plugin@1Add the plugin to your webpack config
// webpack.config.js var LiveReloadPlugin = require('webpack-livereload-changed-chunks-plugin'); module.exports = { plugins: [ new LiveReloadPlugin(options) ] }Add a script tag to your page pointed at the livereload server
<script src="http://localhost:35729/livereload.js"></script>protocol- (Default: protocol of the page, eitherhttporhttps) Protocol for livereload<script>src attribute valueport- (Default: 35729) The desired port for the livereload server. If you define port 0, an available port will be searched for, starting from 35729.hostname- (Default: hostname of the page, likelocalhostor10.0.2.2) The desired hostname for the appended<script>(if present) to point toappendScriptTag- (Default: false) Append livereload<script>automatically to<head>.ignore- (Default:null) RegExp of files to ignore. Null value means ignore nothing.delay- (Default:0) amount of milliseconds by which to delay the live reload (in case build takes longer)
Yes, there's already webpack-dev-server that handles live reloading and more complex scenarios. This project aims to solve the case where you want assets served by your app server, but still want reloads triggered from webpack's build pipeline.
If you set key, cert, or pfx options, they'll get passed through to tiny-lr as options and it will serve over HTTPS. You'll also also set protocol to https.