-
-
Notifications
You must be signed in to change notification settings - Fork 76
/
Copy pathwebpack.config.js
49 lines (47 loc) · 1.29 KB
/
webpack.config.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
38
39
40
41
42
43
44
45
46
47
48
49
const path = require('path');
const fs = require('fs');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const CssMinimizerPlugin = require("css-minimizer-webpack-plugin");
const TerserPlugin = require('terser-webpack-plugin');
module.exports = [{
entry: {
common: "./src/common.js",
index: "./src/index.js",
settings: "./src/settings.js"
},
// mode: 'development',
mode: 'production',
output: {
path: path.resolve(__dirname, 'assets'),
//publicPath: "./",
filename: '[name].bundle.js',
},
externals: [function (context, request, cb) {
if (/^[a-z\-0-9]+$/.test(request)) {
cb(null, 'commonjs ' + request);
return;
}
cb();
}],
plugins: [new MiniCssExtractPlugin()],
optimization: {
minimize: true,
minimizer: [
// For webpack@5 you can use the `...` syntax to extend existing minimizers (i.e. `terser-webpack-plugin`), uncomment the next line
// `...`,
new CssMinimizerPlugin(),
new TerserPlugin()
],
},
module: {
rules: [{
test: /\.m?js$/, exclude: /(node_modules|bower_components)/, use: {
loader: 'babel-loader', options: {
presets: ['@babel/preset-env']
}
}
}, {
test: /\.css$/, use: [MiniCssExtractPlugin.loader, 'css-loader'],
},]
}
}]