日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問(wèn)題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷(xiāo)解決方案
Vue中webpack常規(guī)打包優(yōu)化的示例分析-創(chuàng)新互聯(lián)

這篇文章主要介紹了Vue中webpack常規(guī)打包優(yōu)化的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

目前成都創(chuàng)新互聯(lián)公司已為千余家的企業(yè)提供了網(wǎng)站建設(shè)、域名、網(wǎng)絡(luò)空間、網(wǎng)站改版維護(hù)、企業(yè)網(wǎng)站設(shè)計(jì)、石林網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長(zhǎng),共同發(fā)展。

分析打包文件

要優(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
 })
)

Vue中webpack常規(guī)打包優(yōu)化的示例分析

通過(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()
 ]
...

效果如下:

 Vue中webpack常規(guī)打包優(yōu)化的示例分析

資源與依賴(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 多線程執(zhí)行

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

安裝

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)成都網(wǎng)站設(shè)計(jì)公司,關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、網(wǎng)站設(shè)計(jì)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。


本文標(biāo)題:Vue中webpack常規(guī)打包優(yōu)化的示例分析-創(chuàng)新互聯(lián)
標(biāo)題網(wǎng)址:http://www.dlmjj.cn/article/csddos.html