-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathwebpack.config.js
More file actions
70 lines (65 loc) · 1.7 KB
/
webpack.config.js
File metadata and controls
70 lines (65 loc) · 1.7 KB
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
const path = require("path");
const webpack = require("webpack");
const HtmlWebpackPlugin = require("html-webpack-plugin");
const { CleanWebpackPlugin } = require("clean-webpack-plugin");
const CopyPlugin = require("copy-webpack-plugin");
const glob = require("glob");
const WebpackParallelUglifyPlugin = require("webpack-parallel-uglify-plugin");
const PurifyCSSPlugin = require("purifycss-webpack");
let lists = [];
let HtmlPluginLists = [];
function getList(path) {
var list = glob.sync(path);
console.log(list);
list.forEach((item, index) => {
console.log(item.split("/"));
var name = item.split("/")[3].split(".")[0];
lists[index] = {};
lists[index].name = name;
lists[index].src = item.split(".html")[0];
});
}
function entryList(path) {
getList(path);
lists.forEach((item, index) => {
HtmlPluginLists[index] = new HtmlWebpackPlugin({
filename: item.name + ".html",
template: item.src + ".html",
hash: true,
});
});
return HtmlPluginLists;
}
module.exports = {
entry: {
"main-ts": glob.sync("./src/**/*.ts"),
"main-js": glob.sync("./src/**/*.js"),
"main-html": glob.sync("./src/**/*.html"),
},
output: {
path: path.resolve(__dirname, "dist"),
filename: "[name].[chunkhash].js",
chunkFilename: "[name].[chunkhash].js",
},
optimization: {
splitChunks: {
chunks: "all",
},
},
mode: "development",
devtool: "inline-source-map",
module: {
rules: [{ test: /\.ts$/, use: "ts-loader" }],
},
devServer: {
contentBase: "./dist",
},
resolve: {
extensions: [".tsx", ".ts", ".js"],
modules: ["node_modules"],
},
plugins: [
new CleanWebpackPlugin(),
...entryList("./src/html/*.html"),
],
};