国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - vue.js - vue.config.js打包優化配置

vue.config.js打包優化配置

2022-03-10 16:24網癮頹廢 vue.js

這篇文章主要介紹了vue.config.js打包優化配置,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

百度上的資料五花八門讓人眼花繚亂,別急,這時候我替你親身經歷了,有需要的可以參考下,先上效果圖,以免你們以為我吹牛逼,嘻嘻

優化方向
1.圖片資源壓縮
2.將 productionSourceMap 設為 false,map不進行生成
3.cdn配置(可選)
4.代碼壓縮
5.公共代碼抽離(個人感覺沒啥用)

未優化之前的 //感覺太大了 抬它

vue.config.js打包優化配置

優化之后的

vue.config.js打包優化配置

廢話不多說了,上代碼是重點
這些是必要的下載
/*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

延伸 · 閱讀

精彩推薦
  • vue.jsVue多選列表組件深入詳解

    Vue多選列表組件深入詳解

    這篇文章主要介紹了Vue多選列表組件深入詳解,這個是vue的基本組件,有需要的同學可以研究下...

    yukiwu6752022-01-25
  • vue.jsVue2.x 項目性能優化之代碼優化的實現

    Vue2.x 項目性能優化之代碼優化的實現

    這篇文章主要介紹了Vue2.x 項目性能優化之代碼優化的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋...

    優小U9632022-02-21
  • vue.jsVue項目中實現帶參跳轉功能

    Vue項目中實現帶參跳轉功能

    最近做了一個手機端系統,其中遇到了父頁面需要攜帶參數跳轉至子頁面的問題,現已解決,下面分享一下實現過程,感興趣的朋友一起看看吧...

    YiluRen丶4302022-03-03
  • vue.jsVue中引入svg圖標的兩種方式

    Vue中引入svg圖標的兩種方式

    這篇文章主要給大家介紹了關于Vue中引入svg圖標的兩種方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的...

    十里不故夢10222021-12-31
  • vue.jsVue2.x-使用防抖以及節流的示例

    Vue2.x-使用防抖以及節流的示例

    這篇文章主要介紹了Vue2.x-使用防抖以及節流的示例,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Kyara6372022-01-25
  • vue.js詳解vue 表單綁定與組件

    詳解vue 表單綁定與組件

    這篇文章主要介紹了vue 表單綁定與組件的相關資料,幫助大家更好的理解和學習使用vue框架,感興趣的朋友可以了解下...

    Latteitcjz6432022-02-12
  • vue.js用vite搭建vue3應用的實現方法

    用vite搭建vue3應用的實現方法

    這篇文章主要介紹了用vite搭建vue3應用的實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下...

    Asiter7912022-01-22
  • vue.js梳理一下vue中的生命周期

    梳理一下vue中的生命周期

    看過很多人講vue的生命周期,但總是被繞的云里霧里,尤其是自學的同學,可能js的基礎也不是太牢固,聽起來更是吃力,那我就已個人之淺見,以大白話...

    CRMEB技術團隊7992021-12-22
主站蜘蛛池模板: 日本久久久久久久久久久久 | 午夜成人在线视频 | 久久久久国产精品免费 | 免费看的毛片 | 国产欧美日韩综合精品一区二区 | 中文字幕乱码亚洲无线三区 | 伊人网站 | 一区二区三区四区在线 | 国产一区二区三区午夜 | 在线视频不卡一区 | 亚洲人成网站在e线播放 | 99久久久精品国产一区二区 | 国产一区二区三区在线视频 | 超碰美女 | 亚洲天堂久久 | 一级毛片免费版 | 一区二区免费看 | 欧美精品在线一区二区三区 | 国产精品一区二区无线 | 免费视频二区 | 91欧美激情一区二区三区成人 | 欧美日韩精品免费 | 亚洲精品一区二区三区在线观看 | 97国产精品视频 | 黄色毛片一级 | 国产日韩精品视频 | 国产中文字幕网 | 成人性生交大片免费网站 | 精品久久久久久亚洲综合网 | 亚洲精品www久久久久久广东 | 婷婷久久五月 | 国产在线免费 | 日韩欧美专区 | 亚洲欧美成人a毛片 | 伊人网网站 | 国产精品爱久久久久久久 | 免看一级一片 | 日本精品一区二区三区在线观看 | 国产亚洲欧美另类一区二区三区 | 国产成人精品一区二区三区网站观看 | 欧洲一级毛片 |