Skip to content

Build Webpack chunks only when requested. Optimizes starting time of dev server, regardless of code size.

License

Notifications You must be signed in to change notification settings

tfoxy/webpack-lazy-dev-build

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

14 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

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.

About

Build Webpack chunks only when requested. Optimizes starting time of dev server, regardless of code size.

Resources

License

Stars

Watchers

Forks

Packages

No packages published