-
Notifications
You must be signed in to change notification settings - Fork 127
/
Copy pathvue.config.js
156 lines (145 loc) · 4.99 KB
/
vue.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
148
149
150
151
152
153
154
155
156
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer')
.BundleAnalyzerPlugin
const IS_DEV = process.env.NODE_ENV !== 'production'
/**
* @todo 开发环境配置
* 某些实用工具, plugins 和 loaders 都只能在构建生产环境时才有用
* 在开发时使用 UglifyJsPlugin 来压缩和修改代码是没有意义的,不压缩
*/
const DEVELOPMENT = webpackConfig => {
/**
* @todo 启用 eval-source-map 更好的测试
* 每个模块使用 eval() 执行,并且 source map 转换为 DataUrl 后添加到 eval() 中。
* 初始化 source map 时比较慢,但是会在重新构建时提供比较快的速度,并且生成实际的文件。
* 行数能够正确映射,因为会映射到原始代码中。它会生成用于开发环境的最佳品质的 source map。
*/
webpackConfig.store.set('devtool', 'eval-source-map')
webpackConfig.plugin('html').tap(([options]) => [
Object.assign(options, {
minify: false,
chunksSortMode: 'none'
})
])
// webpackConfig.plugin('BundleAnalyzerPlugin').use(BundleAnalyzerPlugin)
return webpackConfig
}
/**
* @todo 生产环境配置
* 每个额外的 loader/plugin 都有启动时间。尽量少使用不同的工具
*/
const PRODUCTION = webpackConfig => {
/**
* @todo 不需要启用 source-map,去除 console 的情况下 source-map 根本没用,还浪费大量时间和空间
* 详情见:https://webpack.js.org/configuration/devtool/#devtool
*/
webpackConfig.store.set('devtool', '')
webpackConfig.plugin('html').tap(([options]) => [
Object.assign(options, {
minify: {
removeComments: true,
removeCommentsFromCDATA: true,
collapseWhitespace: true,
conservativeCollapse: false,
collapseInlineTagWhitespace: true,
collapseBooleanAttributes: true,
removeRedundantAttributes: true,
removeAttributeQuotes: false,
removeEmptyAttributes: true,
removeScriptTypeAttributes: true,
removeStyleLinkTypeAttributes: true,
useShortDoctype: true,
minifyJS: true,
minifyCSS: true
},
cache: true, // 仅在文件被更改时发出文件
hash: true, // true则将唯一的webpack编译哈希值附加到所有包含的脚本和CSS文件中,这对于清除缓存很有用
scriptLoading: 'defer', // 现代浏览器支持非阻塞javascript加载('defer'),以提高页面启动性能。
inject: true, // true所有javascript资源都将放置在body元素的底部
chunksSortMode: 'none'
})
])
return webpackConfig
}
module.exports = {
publicPath: IS_DEV ? '/' : '/vue3-ts-base',
css: {
loaderOptions: {
less: {
globalVars: {},
srouceMap: IS_DEV,
lessOptions: {
javascriptEnabled: true
}
}
}
},
devServer: {
proxy: 'http://10.10.10.115:8002'
},
pluginOptions: {
/** 全局加载less 的 webpack 插件 */
'style-resources-loader': {
preProcessor: 'less',
patterns: ['./src/styles/index.less']
}
},
/**
* @description 去掉 console信息
* config.optimization.minimizer[0].options.terserOptions.compress.drop_console = true;
* html-webpack-plugin插件配置详情见 https://github.com/jantimon/html-webpack-plugin#options
*/
configureWebpack: config => {
config.optimization = {
splitChunks: {
chunks: 'all',
minSize: 3000, // (默认值:30000)块的最小大小。
minChunks: 1, //(默认值:1)在拆分之前共享模块的最小块数
maxAsyncRequests: 5, //(默认值为5)按需加载时并行请求的最大数量
maxInitialRequests: 6, // (默认值为3)入口点的最大并行请求数
automaticNameDelimiter: '-',
name: true,
cacheGroups: {
lodash: {
name: 'lodash',
test: /[\\/]node_modules[\\/]lodash[\\/]/,
priority: 20
},
vue: {
name: 'vue',
test: /[\\/]node_modules[\\/]vue[\\/]/
},
vuex: {
name: 'vuex',
test: /[\\/]node_modules[\\/]vuex[\\/]/
},
'vuex-presistedstate': {
name: 'vuex-presistedstate',
test: /[\\/]node_modules[\\/]vuex-presistedstate[\\/]/
},
'vue-router': {
name: 'vue-router',
test: /[\\/]node_modules[\\/]vue-router[\\/]/
},
'ant-design-vue': {
name: 'ant-design-vue',
test: /[\\/]node_modules[\\/]ant-design-vue[\\/]/
},
moment: {
name: 'moment',
test: /[\\/]node_modules[\\/]moment[\\/]/,
priority: 40
}
}
}
}
},
chainWebpack: config => {
config.resolve.symlinks(true)
if (process.env.use_analyzer) {
config.plugin('webpack-bundle-analyzer').use(BundleAnalyzerPlugin)
}
IS_DEV ? DEVELOPMENT(config) : PRODUCTION(config)
},
productionSourceMap: false,
lintOnSave: true
}