-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcraco.config.js
147 lines (143 loc) · 3.72 KB
/
craco.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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
/**
* @author Kevin
* @Date: 2024-4-16
*/
const path = require("path")
const TerserPlugin = require("terser-webpack-plugin")
const CracoLessPlugin = require("craco-less")
const { whenProd } = require("@craco/craco")
module.exports = {
devServer: {
port: 1819,
open: false
},
webpack: {
alias: {
"@": path.resolve("src"),
"@statics": path.resolve(__dirname, "src/statics"),
"@views": path.resolve(__dirname, "src/views"),
"@comp": path.resolve(__dirname, "src/components"),
"@services": path.resolve(__dirname, "src/services"),
"@utils": path.resolve(__dirname, "src/utils"),
"@redux": path.resolve(__dirname, "src/redux"),
"@styles": path.resolve(__dirname, "src/styles")
},
publicPath: "/",
plugins: [
// 打压缩包
...whenProd(() => [
// new BundleAnalyzerPlugin()
], [])
],
configure: (webpackConfig, { env: webpackEnv, paths }) => {
webpackConfig.devtool = process.env.NODE_ENV === "development" ? "source-map" : false;
webpackConfig.entry = path.resolve(__dirname, 'src', 'renderer/entry/index.js')
webpackConfig.resolve.fallback = {
"path": false
};
webpackConfig.ignoreWarnings = [/Failed to parse source map/]
webpackConfig.module.rules.push({
test: /\.(js|mjs|jsx|svg)$/,
enforce: "pre",
loader: require.resolve("source-map-loader"),
resolve: {
fullySpecified: false
}
})
whenProd(() => {
webpackConfig.optimization.minimize = true
webpackConfig.optimization.minimizer.map(plugin => {
/**
* 重写压缩配置 TerserPlugin (这个需要 nginx 配合使用,不然nginx会加载压缩前的文件, nginx 配置后,会加载压缩后的文件)
* nginx的gzip配置
* gzip on;
* gzip_buffers 32 4K;
* gzip_comp_level 6;
* gzip_min_length 100;
* gzip_types application/javascript text/css text/xml;
* gzip_disable "MSIE [1-6]\."; #配置禁用gzip条件,支持正则。此处表示ie6及以下不启用gzip(因为ie低版本不支持)
* gzip_vary on;
*/
if (plugin instanceof TerserPlugin) {
Object.assign(plugin.options.minimizer.options.compress, {
drop_debugger: true, // 删除 debugger
drop_console: true, // 删除 console
pure_funcs: ["console.log"]
})
}
return plugin
})
webpackConfig.optimization.runtimeChunk = "single"
webpackConfig.optimization.splitChunks = {
...webpackConfig.optimization.splitChunks,
chunks: "all",
minSize: 30000,
maxAsyncRequests: 30,
maxInitialRequests: 30,
cacheGroups: {
defaultVendors: {
test: /[\\/]node_modules[\\/]/,
name: "vendors"
},
antd: {
test: /antd/,
name: "antd",
priority: 90
},
echarts: {
test: /echarts/,
name: "echarts",
priority: 90
},
craco: {
test: /@craco/,
name: "@craco",
priority: 90
},
antDesign: {
test: /@ant-design/,
name: "@ant-design",
priority: 90
},
lodash: {
test: /lodash/,
name: "lodash",
priority: 90
},
base: {
// 基本框架
chunks: "all",
test: /(react|react-dom|react-dom-router)/,
name: "base",
priority: 100
},
commons: {
chunks: "all",
// 将两个以上的chunk所共享的模块打包至commons组。
minChunks: 2,
name: "commons",
priority: 110
}
}
}
})
return webpackConfig
}
},
babel: {
plugins: [
...whenProd(
() => [
["@babel/plugin-proposal-decorators", { legacy: true }]
],
[]
)
]
},
plugins: [{
plugin: CracoLessPlugin,
}],
eslint: {
enable: false
}
}