About the Build Mode with Webpack

You would build the Webpack bundle for development with:

1
$ npx webpack --config webpack.config.js --mode=development

and for production with:

1
$ npx webpack --config webpack.config.js --mode=production

To know whether the current build is in development mode or production mode, you should use webpack.DefinePlugin() in webpack.config.js:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
const webpack = require('webpack');

module.exports = (env, argv) => {
    return {
        // other directives...
        plugins: [
            new webpack.DefinePlugin({
                PRODUCTION: JSON.stringify(argv.mode === 'production'),
            }),
        ],
    }
};

Then in your bundled JavaScript files you can have this checking:

1
2
3
4
5
if (PRODUCTION) {
    console.log("This is a production build.");
} else {
    console.log("This is a development build.");
}

Note that PRODUCTION here will work not as a global variable, but as a template variable resolved to true or false.

Tips and Tricks Programming Dev Ops JavaScript Webpack