百度上的资料五花八门让人眼花缭乱,别急,这时候我替你亲身经历了,有需要的可以参考下,先上效果图,以免你们以为我吹牛逼,嘻嘻
优化方向
1.图片资源压缩
2.将 productionSourceMap 设为 false,map不进行生成
3.cdn配置(可选)
4.代码压缩
5.公共代码抽离(个人感觉没啥用)
未优化之前的 //感觉太大了 抬它
优化之后的
废话不多说了,上代码是重点
这些是必要的下载
/*cnpm install image-webpack-loader --save-dev
cnpm install compression-webpack-plugin --save-dev
cnpm install uglifyjs-webpack-plugin --save-dev */
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
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
|
const path = require( 'path' ); // gzip压缩 const CompressionPlugin = require( 'compression-webpack-plugin' ) //监控日志 const SentryCliPlugin = require( '@sentry/webpack-plugin' ); // 代码压缩 const UglifyJsPlugin = require( 'uglifyjs-webpack-plugin' ) const Version = new Date().getTime(); function resolve(dir) { return path.join(__dirname, dir) } const cdn = { js: [ // vue必须在第一个 'https://cdn.bootcss.com/vue/2.6.10/vue.min.js' , 'https://cdn.bootcss.com/vuex/3.1.0/vuex.min.js' , 'https://cdn.bootcss.com/vue-router/3.0.6/vue-router.min.js' , 'https://cdn.bootcss.com/axios/0.18.1/axios.min.js' , 'https://cdn.bootcss.com/qs/6.5.1/qs.min.js' , 'https://cdn.jsdelivr.net/npm/vant@2.5.4/lib/vant.min.js' ] } module.exports = { //部署应用包时的基本 URL publicPath: './' , //当运行 vue-cli-service build 时生成的生产环境构建文件的目录 outputDir: 'wx_vue' , //放置生成的静态资源 (js、css、img、fonts) 的 (相对于 outputDir 的) 目录 assetsDir: './' + Version + '/assets' , // eslint-loader 是否在保存的时候检查 安装@vue/cli-plugin-eslint有效 lintOnSave: false , //是否使用包含运行时编译器的 Vue 构建版本。设置true后你就可以在使用template runtimeCompiler: true , // 生产环境是否生成 sourceMap 文件 sourceMap的详解请看末尾 productionSourceMap: false , /** 去掉hash */ filenameHashing: true , // pages: { // index: { // entry: 'src/main.js', // template: 'public/index.html', // filename: 'index.html' // } // }, configureWebpack: config => { if (process.env.NODE_ENV === 'production' ) { // 为生产环境修改配置... config.mode = 'production' config.devtool = "source-map" ; } else { // 为开发环境修改配置... config.mode = 'development' } /** 删除懒加载模块的 prefetch preload,降低带宽压力(使用在移动端) */ config.plugins. delete ( "prefetch" ). delete ( "preload" ) config.optimization.minimize( true ) // gzip压缩 // config.plugin("compressionPlugin").use(CompressionPlugin).tap(() => [ // { // filename: '[path].gz[query]', // algorithm: 'gzip', // test: /\.js$|\.html$|\.css/, //匹配文件名 // threshold: 10240, //超过10k进行压缩 // minRatio: 0.8, // 只有压缩率小于这个值的资源才会被处理 // deleteOriginalAssets: false //是否删除源文件 // } // ]) config.plugins.push( new CompressionPlugin({ filename: '[path].gz[query]' , algorithm: 'gzip' , test: /\.js$|\.html$|\.css/, threshold: 10240, // 只有大小大于该值的资源会被处理 10240 minRatio: 0.8, // 只有压缩率小于这个值的资源才会被处理 deleteOriginalAssets: false // 删除原文件 }) ) // 公共代码抽离 config.optimization = { splitChunks: { cacheGroups: { vendor: { chunks: 'all' , test: /node_modules/, name: 'vendor' , minChunks: 1, maxInitialRequests: 5, minSize: 0, priority: 100 }, common: { chunks: 'all' , test: /[\\/]src[\\/]js[\\/]/, name: 'common' , minChunks: 2, maxInitialRequests: 5, minSize: 0, priority: 60 }, styles: { name: 'styles' , test: /\.(sa|sc|c)ss$/, chunks: 'all' , enforce: true }, runtimeChunk: { name: 'manifest' } } } } }, configureWebpack: { resolve: { alias: { 'vue$' : 'vue/dist/vue.esm.js' , '@' : resolve( 'src' ), '@c' : path.resolve(__dirname, './src/components' ), 'assets' : path.resolve(__dirname, '../src/assets' ) } }, externals: { 'vue' : 'Vue' , 'vuex' : 'Vuex' , 'vue-router' : 'VueRouter' , 'axios' : 'axios' , 'qs' : 'Qs' , 'vant' : 'Vant' // 'weixin-js-sdk':'weixin-js-sdk', // 'clipboard':'clipboard', // 'qrcodejs2':'qrcodejs2', // 'js-md5':'js-md5' }, optimization: { minimizer: [ new UglifyJsPlugin({ uglifyOptions: { output: { // 删除注释 comments: false }, //生产环境自动删除console compress: { //warnings: false, // 若打包错误,则注释这行 drop_debugger: true , //清除 debugger 语句 drop_console: true , //清除console语句 pure_funcs: [ 'console.log' ] } }, sourceMap: false , parallel: true }) ] } }, // css相关配置 css: { extract: false , loaderOptions: { stylus: { 'resolve url' : true , 'import' : [] }, // less: { // // `globalVars` 定义全局对象,可加入全局变量 // globalVars: { // primary: '#333' // } // } }, requireModuleExtension: true , }, // webpack-dev-server 相关配置 devServer: { // 设置代理 hot: true , //热加载 host: 'localhost' , //ip地址 port: 8085, //端口 https: false , //false关闭https,true为开启 open: true , //自动打开浏览器 proxy: { //配置多个跨域 '/api' : { //本地 //target: 'http://172.168.10.150:81/ysol_wx', //target: 'http://yishanonline.cn/ysol_wx', target: 'https://yishanol.cn/ysol_wx' , ws: true , changeOrigin: true , pathRewrite: { '^/api' : '' } } } }, pluginOptions: { // 第三方插件配置 // ... }, chainWebpack: config => { // ============压缩图片 start============ config.module .rule( 'images' ) .use( 'image-webpack-loader' ) .loader( 'image-webpack-loader' ) .options({ //{ bypassOnDebug: true } mozjpeg: { progressive: true , quality: 65 }, Compress JPEG images optipng: { enabled: false }, // Compress PNG images pngquant: { quality: [0.65, 0.9], speed: 4 }, // Compress PNG images gifsicle: { interlaced: false }, // Compress SVG images // webp: { quality: 75 } }) .end() // config.module.rules.push({ // test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, // use:[{ // loader: 'image-webpack-loader', // options: {bypassOnDebug: true} // }] // }) // ============压缩图片 end============ config.plugin( 'html' ).tap(args => { args[0].cdn = cdn return args }) /* 添加分析工具*/ if (process.env.NODE_ENV === 'production' ) { if (process.env.npm_config_report) { config .plugin( 'webpack-bundle-analyzer' ) .use(require( 'webpack-bundle-analyzer' ).BundleAnalyzerPlugin) .end(); config.plugins. delete ( 'prefetch' ) } } if (process.env.UMI_ENV === 'production' ) { //当为prod时候才进行sourcemap的上传,如果不判断,在项目运行的打包也会上传 这个为线上日志输出 不需要的可以删除掉 config.plugin( "sentry" ).use(SentryCliPlugin, [{ ignore: [ 'node_modules' ], include: /\.map$/, //上传dist文件的js configFile: 'sentry.properties' , //配置文件地址,这个一定要有,踩坑在这里,忘了写导致一直无法实现上传sourcemap release: 'release@0.0.1' , //版本号,自己定义的变量,整个版本号在项目里面一定要对应 deleteAfterCompile: true , urlPrefix: '~/wx_vue/' //cdn js的代码路径前缀 }]) } } } |
vue3 vue.config.js相对于vue2的话呢,更加简洁,你需要什么的操作,你得自己配置,增加自己的动手能力,除了一些语法上的改变,在有些写法上还是差不多的!打包优化的路还长,下次接着更
到此这篇关于vue.config.js打包优化配置的文章就介绍到这了,更多相关vue.config.js打包优化内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!
原文链接:https://blog.csdn.net/weixin_44021417/article/details/106668042