這篇文章主要介紹了Vue中webpack常規(guī)打包優(yōu)化的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
創(chuàng)新互聯(lián)公司,是成都地區(qū)的互聯(lián)網(wǎng)解決方案提供商,用心服務(wù)為企業(yè)提供網(wǎng)站建設(shè)、成都app軟件開(kāi)發(fā)、小程序設(shè)計(jì)、系統(tǒng)定制設(shè)計(jì)和微信代運(yùn)營(yíng)服務(wù)。經(jīng)過(guò)數(shù)十載的沉淀與積累,沉淀的是技術(shù)和服務(wù),讓客戶(hù)少走彎路,踏實(shí)做事,誠(chéng)實(shí)做人,用情服務(wù),致力做一個(gè)負(fù)責(zé)任、受尊敬的企業(yè)。對(duì)客戶(hù)負(fù)責(zé),就是對(duì)自己負(fù)責(zé),對(duì)企業(yè)負(fù)責(zé)。
分析打包文件
要優(yōu)化,先分析。我們先要知道到底是哪里拖慢我們的打包速度呢?
打包后生成文件分析
可以利用 webpack-bundle-analyzer
插件來(lái)分析我們打包后生成的文件
安裝
npm i webpack-bundle-analyzer -D
使用
修改 webpack.prod.conf.js
文件
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin // 構(gòu)建完成后,瀏覽器會(huì)自動(dòng)打開(kāi)localhost:8080 webpackConfig.plugins.push( new BundleAnalyzerPlugin({ analyzerPort: 8080, generateStatsFile: false }) )
通過(guò)圖片可以看到打包后文件的具體信息
打包進(jìn)度條顯示,可以查看到打包進(jìn)度百分比
simple-progress-webpack-plugin
可以顯示打包百分比
安裝
npm i simple-progress-webpack-plugin -D
使用
修改 webpack.prod.conf.js
文件
const SimpleProgressWebpackPlugin = require( 'simple-progress-webpack-plugin' ) ... plugins: [ new SimpleProgressWebpackPlugin() ] ...
效果如下:
資源與依賴(lài)包的控制
通過(guò)上面進(jìn)度可以看到,打包過(guò)程中,卡頓在壓縮的地方過(guò)長(zhǎng),當(dāng)項(xiàng)目越來(lái)越臃腫的時(shí)候,我們要需要對(duì)項(xiàng)目靜態(tài)資源以及依賴(lài)包進(jìn)行整理,
圖片過(guò)大的可以壓縮,這里推薦一個(gè)還不錯(cuò)的壓縮 鏈接
項(xiàng)目中沒(méi)有使用的依賴(lài)可以刪除,可以按需引用的依賴(lài),按需引用
項(xiàng)目里面使用 ElementUI 和 Echarts 都是全部引用掛在 Vue.prototype 上,現(xiàn)都改為按需引用。
減少文件搜索范圍
設(shè)置 resolve.alias
字段,避免打包時(shí)如果使用相對(duì)路徑訪問(wèn)或著 import 文件時(shí)會(huì)層層去查找解析文件
resolve: { alias: { '@': resolve('src') } }
合理配置 extensions 擴(kuò)展名
resolve.extensions
能夠自動(dòng)解析確定的擴(kuò)展,但是如果 extensions 擴(kuò)展名過(guò)多,會(huì)導(dǎo)致解析過(guò)程過(guò)多,所以我們要合理配置擴(kuò)展名,不要過(guò)多配置擴(kuò)展名,項(xiàng)目引用多的文件,擴(kuò)展名放在前面,我司項(xiàng)目中多的是 vue , js 文件,可以只引用這兩種。
resolve: { extensions: ['.vue', '.js'] }
loader 預(yù)處理文件增加 include 匹配特定條件
預(yù)處理各種文件時(shí)指定匹配目錄后, webpack 解析文件時(shí)就不會(huì)循環(huán)查找其他目錄,加快解析速度。
happypack 多線(xiàn)程執(zhí)行
webpack 執(zhí)行預(yù)處理文件時(shí)單線(xiàn)程的,我們可以使用 happypack 來(lái)多線(xiàn)程處理文件。
安裝
npm i happypack -D
使用
修改 webpack.base.js
文件
const happyThreadPool = HappyPack.ThreadPool({ size: os.cpus().length }); module: { rules: [ { test: /\.js$/, loader: 'happypack/loader?id=babel', // 原始loader替換成`happypack/loader` include: [resolve('src')] } ] }, plugins: [ new HappyPack({ // id標(biāo)識(shí) 需要處理的loader id: 'babel', // loader配置和原始配置一樣 loaders: [ { loader: 'babel-loader', options: { presets: ['es2015'], cacheDirectory: true } } ], threadPool: happyThreadPool }) ]
babel-plugin-dynamic-import-node 異步加載
babel-plugin-dynamic-import-node
插件是使 import() 替換成 require 編譯
安裝
npm i babel-plugin-dynamic-import-node -D
使用
修改 .babelrc 文件
"env": { "development": { "plugins": ["dynamic-import-node"] }, "production": { "plugins": ["dynamic-import-node"] } }
注意:使用插件 build 后沒(méi)有 chunk files 文件。
感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“Vue中webpack常規(guī)打包優(yōu)化的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!
文章名稱(chēng):Vue中webpack常規(guī)打包優(yōu)化的示例分析
文章URL:http://www.rwnh.cn/article34/gjhhse.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站策劃、企業(yè)建站、網(wǎng)站建設(shè)、定制網(wǎng)站、、定制開(kāi)發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)