国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

Vue項(xiàng)目總結(jié)之webpack常規(guī)打包優(yōu)化方案

2019-11-19 11:23:04
字體:
供稿:網(wǎng)友

由于新建項(xiàng)目發(fā)版打包時(shí)間大概需要 30分鐘 ,發(fā)版時(shí) 嚴(yán)重 拖慢 下班 時(shí)間,所以特意查看了相關(guān)文檔來優(yōu)化打包速度,爭(zhēng)取早點(diǎn)下班,^_^。

分析打包文件

要優(yōu)化,先分析。我們先要知道到底是哪里拖慢我們的打包速度呢?

打包后生成文件分析

可以利用 webpack-bundle-analyzer 插件來分析我們打包后生成的文件

安裝

npm i webpack-bundle-analyzer -D

使用

修改 webpack.prod.conf.js 文件

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin// 構(gòu)建完成后,瀏覽器會(huì)自動(dòng)打開localhost:8080webpackConfig.plugins.push( new BundleAnalyzerPlugin({  analyzerPort: 8080,  generateStatsFile: false }))

通過圖片可以看到打包后文件的具體信息

打包進(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() ]...

效果如下:

 

資源與依賴包的控制

通過上面進(jìn)度可以看到,打包過程中,卡頓在壓縮的地方過長,當(dāng)項(xiàng)目越來越臃腫的時(shí)候,我們要需要對(duì)項(xiàng)目靜態(tài)資源以及依賴包進(jìn)行整理,

圖片過大的可以壓縮,這里推薦一個(gè)還不錯(cuò)的壓縮 鏈接

  • 項(xiàng)目中沒有使用的依賴可以刪除,可以按需引用的依賴,按需引用
  • 項(xiàng)目里面使用 ElementUI 和 Echarts 都是全部引用掛在 Vue.prototype 上,現(xiàn)都改為按需引用。

減少文件搜索范圍

設(shè)置 resolve.alias 字段,避免打包時(shí)如果使用相對(duì)路徑訪問或著 import 文件時(shí)會(huì)層層去查找解析文件

resolve: { alias: {  '@': resolve('src') }}

合理配置 extensions 擴(kuò)展名

resolve.extensions 能夠自動(dòng)解析確定的擴(kuò)展,但是如果 extensions 擴(kuò)展名過多,會(huì)導(dǎo)致解析過程過多,所以我們要合理配置擴(kuò)展名,不要過多配置擴(kuò)展名,項(xiàng)目引用多的文件,擴(kuò)展名放在前面,我司項(xiàng)目中多的是 vue , js 文件,可以只引用這兩種。

resolve: { extensions: ['.vue', '.js']}

loader 預(yù)處理文件增加 include 匹配特定條件

預(yù)處理各種文件時(shí)指定匹配目錄后, webpack 解析文件時(shí)就不會(huì)循環(huán)查找其他目錄,加快解析速度。

happypack 多線程執(zhí)行

webpack 執(zhí)行預(yù)處理文件時(shí)單線程的,我們可以使用 happypack 來多線程處理文件。

安裝

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 后沒有 chunk files 文件。

總結(jié)

項(xiàng)目經(jīng)過以上優(yōu)化,打包從 30 分鐘,到 2 分鐘,整體還有優(yōu)化空間,可以使用其他 cdn , dll 等優(yōu)化方式。

以上所述是小編給大家介紹的Vue項(xiàng)目總結(jié)之webpack常規(guī)打包優(yōu)化方案,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)武林網(wǎng)網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 天长市| 恩施市| 泰和县| 喀什市| 齐河县| 成都市| 喜德县| 泌阳县| 南平市| 思茅市| 玛纳斯县| 剑阁县| 鄄城县| 都江堰市| 青浦区| 凉山| 肇庆市| 曲阜市| 宁晋县| 民县| 和平区| 邵阳县| 赣榆县| 巩义市| 姚安县| 桑日县| 浪卡子县| 蛟河市| 阳曲县| 竹北市| 新巴尔虎右旗| 望城县| 浦县| 潞城市| 大埔县| 金坛市| 康马县| 温州市| 张掖市| 克什克腾旗| 策勒县|