Skip to content

Latest commit

 

History

History
44 lines (31 loc) · 1.55 KB

README.md

File metadata and controls

44 lines (31 loc) · 1.55 KB

webpack-lazy-dev-build

Extends the webpack-dev-middleware to support lazy loading of assets.

Useful when you have multiple entry points, multiple compilers or you are using dynamic imports. If starting the development server is taking you a long time, you are using code splitting and you don't need all assets to be compiled when the server is started, then this package is for you.

Install

npm install --save-dev webpack-lazy-dev-build

Minimum setup

const express = require('express');
const WebpackDevMiddleware = require('webpack-dev-middleware');
const LazyBuild = require('webpack-lazy-dev-build');
const webpackConfig = require('./webpack.config');

const lazyBuild = new LazyBuild();
webpackConfig.plugins.push(lazyBuild.createPlugin());
const compiler = webpack(webpackConfig);
const devMiddleware = WebpackDevMiddleware(compiler);
const app = express();

app.use(lazyBuild.createMiddleware(devMiddleware));

app.listen(3000);

How it works

When the development server is started, no assets are compiled. When the browser requests an entry point, that specific asset is compiled at that moment.

The difference with the lazy mode of webpack-dev-middleware is that when an asset is compiled, it is cached. The second time the asset is requested, no compilation is done. When a file is changed, it will trigger a recompilation of dependant assets that were already compiled. It's like a mix of watch and lazy mode.

You can check an example at webpack-lazy-dev-build-example.