-
Notifications
You must be signed in to change notification settings - Fork 1
/
webpack.prod.js
37 lines (30 loc) · 1.09 KB
/
webpack.prod.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
const path = require('path');
const { merge } = require('webpack-merge');
const common = require('./webpack.common.js');
const OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin');
const TerserPlugin = require('terser-webpack-plugin');
const HtmlCriticalWebpackPlugin = require('html-critical-webpack-plugin');
module.exports = merge(common, {
mode: 'production',
optimization: {
minimizer: [new TerserPlugin({}), new OptimizeCSSAssetsPlugin({})],
},
plugins: [
// Create additional instances of `HtmlCriticalWebpackPlugin`
// to extract different critical files from different sources.
new HtmlCriticalWebpackPlugin({
base: path.resolve(__dirname, 'dist'),
// Local files work, too: 'about.html',
src: 'http://127.0.0.1:7777/dist/',
dest: 'styles/critical.css',
inline: false,
minify: true,
extract: false,
width: 1440,
height: 900,
penthouse: {
blockJSRequests: false,
}
}),
],
});