利用report分析vue項目中各文件大小
report分析vue項目中各文件大小
vendor.js
在Vue項目中,引入到工程中的所有js、css文件,編譯時都會被打包進vendor.js,瀏覽器在加載該文件之后才能開始顯示首屏。
若是引入的庫眾多,那么vendor.js文件體積將會相當(dāng)?shù)拇?,影響首開的體驗。
vue-cli 4 使用report分析vendor.js
Vue Cli(@/vue/cli)自帶的webpack包體積優(yōu)化工具,它可以查看各個模塊的size大小,方便優(yōu)化。
只需要在build后面加上 --report 參數(shù)即可。
1、 我們把命令配置到package.json里
"scripts": { ? "serve": "vue-cli-service serve", ? "build": "vue-cli-service build", ? "report": "vue-cli-service build --report" ?//加入該行 },
2、執(zhí)行npm run report 打包并生成report
注意:網(wǎng)上很多說要先安裝webpack-bundle-analyzer包,其實不需要安裝。
3、運行 npm run report 后
會在 build 的同時,在dist目錄會生成一個report.html,打開后可看到各文件占用大小
vue項目打包文件大小分析
vuecli3.0項目搭建與webpack-bundle-analyzer分析
首先說一下vuecli低版本與cli3.0的項目結(jié)構(gòu)的區(qū)別
少了build config 文件夾 如果需要進行webpack等配置
需要在根目錄新建 vue.config.js
cli低版本
cli高版本
vue.config.js 文件內(nèi)容 本次只記錄 打包大小分析以及優(yōu)化包大小
module.exports = { publicPath: './', // 輸出文件目錄 outputDir: 'dist', // 靜態(tài)資源目錄 (js, css, img, fonts) assetsDir: 'assets', // webpack-dev-server 相關(guān)配置 devServer: { // 默認(rèn)打開瀏覽器 open: true, // 端口號 port: 8080, }, // webpack 配置 chainWebpack: (config) => { // 第一 增加打包文件大小分析 if (process.env.use_analyzer) { config .plugin('webpack-bundle-analyzer') .use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin) } }, //webpack配置 configureWebpack: config => { //警告 webpack 的性能提示 config.performance = { hints: 'warning', //入口起點的最大體積 maxEntrypointSize: 50000000, //生成文件的最大體積 maxAssetSize: 30000000, //只給出 js 文件的性能提示 assetFilter: function (assetFilename) { return assetFilename.endsWith('.js'); } }, // 打包忽略 config.externals = { 'vue': 'Vue', 'vue-router': 'VueRouter', 'element-ui': 'ELEMENT' } } }
第一 打包分析 webpack-bundle-analyzer
首先 下載依賴 npm intall webpack-bundle-analyzer –save-dev
其次 在vue.config.js文件配置
chainWebpack: config => { ? ? ? ? config ? ? ? ? ? ? .plugin('webpack-bundle-analyzer') ? ? ? ? ? ? .use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin) ? ? }
可以再package.json加入啟動的命令
"scripts": { "analyz": "use_analyzer=true npm run serve" }
效果圖
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
關(guān)于vuex的數(shù)據(jù)持久化處理方式
這篇文章主要介紹了關(guān)于vuex的數(shù)據(jù)持久化處理方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10Vue.js基礎(chǔ)指令實例講解(各種數(shù)據(jù)綁定、表單渲染大總結(jié))
這篇文章主要為大家詳細(xì)介紹了Vue.js基礎(chǔ)指令實例,各種數(shù)據(jù)綁定、表單渲染大總結(jié),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07Vue中textarea自適應(yīng)高度方案的實現(xiàn)
本文主要介紹了Vue中textarea自適應(yīng)高度方案的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01