成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

深入了解Vite:依賴預構建原理

開發 前端
? commonJS 與 UMD兼容:因為Vite在開發階段主要是依賴瀏覽器原生ES模塊化規范,所以無論是我們的源代碼還是第三方依賴都得符合ESM的規范,但是目前并不是所有第三方依賴都有ESM的版本,所以需要對第三方依賴進行預編譯,將它們轉換成EMS規范的產物。

前言

前面我們有提到Vite在開發階段,提倡的是一個no-bundle的理念,不必與webpack那樣需要先將整個項目進行打包構建。但是no-bundle的理念只適合源代碼部分(我們自己寫的代碼),vite會將項目中的所有模塊分為依賴與源碼兩部分。

依賴:指的是一些不會變動的一些模塊,如:node_modules中的第三方依賴,這部分代碼vite會在啟動本地服務之前使用esbuild進行預構建。esbuild 使用 Go 編寫,比使用 JavaScript 編寫的打包器預構建依賴快 10-100 倍。

源碼:指的是我們自己開發時寫的那部分代碼,這部分代碼可能會經常變動,并且一般不會同時加載所有源代碼。

所以總結來說:no-bundle是針對源碼的,而預構建是針對第三方依賴的

使用預構建的原因

主要有以下兩點:

  • commonJS 與 UMD兼容:因為Vite在開發階段主要是依賴瀏覽器原生ES模塊化規范,所以無論是我們的源代碼還是第三方依賴都得符合ESM的規范,但是目前并不是所有第三方依賴都有ESM的版本,所以需要對第三方依賴進行預編譯,將它們轉換成EMS規范的產物。

比如React,它就沒有ESM的版本,所以在使用Vite時需要預構建

圖片圖片

  • 性能:為了提高后續頁面的加載性能,Vite將那些具有許多內部模塊的 ESM 依賴項轉換為單個模塊。

比如常用的loads-es

我們引入lodash-es工具包中的debounce方法,此時它理想狀態應該是只發出一個請求

import  { debounce }  from 'lodash-es'

事實也是這樣:

圖片圖片

但這是預構建的功勞,如果我們對lodash-es關閉預構建呢?

vite配置文件加上如下代碼,再來試試:

// vite.config.js
optimizeDeps: {
    exclude: ['lodash-es']
  }

圖片圖片

可以看到,此時發起了600多個請求,這是因為lodash-es 有超過 600 個內置模塊!

vite通過將 lodash-es 預構建成單個模塊,只需要發起一個HTTP請求!可以很大程度地提高加載性能

由于Vite的預構建是基于性能優異的Esbuild來完成的,所以并不會造成明顯的打包性能問題

開啟預構建

默認配置

一般來說,Vite幫我們默認開啟了預構建

圖片圖片

預構建產物會存放在:node_modules/.vite/deps

圖片圖片

里面會有一個_metadata.json的文件,這里保存著已經預構建過的依賴信息

對于預構建產物的請求,Vite會設置為強緩存,有效時間為1年,對于有效期內的請求,會直接使用緩存內容

圖片圖片

如果只有HTTP強緩存肯定也不行,如果用戶更新了依賴版本,在緩存過期之前,瀏覽器拿到的一直是舊版本的內容。

所以Vite對本地文件也設置了緩存判斷,如果下面幾個地方任意一個地方有變動,Vite將會對依賴進行重新預構建:

  • 項目依賴dependencies變更

圖片圖片

  • 各種包管理器的lock文件變更

圖片圖片

  • optimizeDeps配置內容變更

圖片圖片

自定義配置

entries

默認情況下,Vite會抓取項目中的index.html來檢測需要預構建的依賴

optimizeDeps: {
  entries: ['index.html']
}

如果指定了 build.rollupOptions.input,Vite 將轉而去抓取這些入口點。

exclude

排除需要預構建的依賴項

optimizeDeps: {
  exclude: ['lodash-es']
}

include

默認情況下,不在 node_modules 中的依賴不會被預構建。使用此選項可強制選擇預構建的依賴項。

optimizeDeps: {
  include: ['lodash-es']
}

預構建流程

還是從源碼入手,在啟動服務的過程中會執行一個initDepsOptimizer表示初始化依賴優化

圖片圖片

接著找到定義initDepsOptimizer方法的地方

圖片圖片

在這里會執行createDepsOptimizer方法,再接著找到定義createDepsOptimizer的地方

圖片圖片

這里首先會去執行loadCachedDepOptimizationMetadata用于獲取本地緩存中的metadata數據

圖片圖片

該函數會在獲取到_metadata.json文件內容之后去對比lock文件hash以及配置文件optimizeDeps內容,如果一樣說明預構建緩存沒有任何改變,無需重新預構建,直接使用上次預構建緩存即可。

如果沒有緩存時則需要進行依賴掃描:

圖片圖片

這里主要是會調用scanImport方法,從名字也能看出該方法應該是通過掃描項目中的import語句來得到需要預編譯的依賴

圖片圖片

最終會返回一個prepareEsbuildScanner方法:

圖片圖片

最后該方法中會使用esbuild對掃描出來的依賴項進行預編譯。

責任編輯:武曉燕 來源: 前端南玖
相關推薦

2021-01-19 12:00:39

前端監控代碼

2021-04-28 10:13:58

zookeeperZNode核心原理

2024-04-12 07:51:05

SpringBean初始化

2021-01-12 09:03:17

MySQL復制半同步

2010-07-13 09:36:25

2010-11-19 16:22:14

Oracle事務

2020-09-21 09:53:04

FlexCSS開發

2022-08-26 13:48:40

EPUBLinux

2009-08-25 16:27:10

Mscomm控件

2010-06-23 20:31:54

2020-07-20 06:35:55

BashLinux

2020-11-06 16:50:43

工具GitLab CICD

2011-07-18 15:08:34

2022-06-03 10:09:32

威脅檢測軟件

2010-11-15 11:40:44

Oracle表空間

2018-06-22 13:05:02

前端JavaScript引擎

2010-09-27 09:31:42

JVM內存結構

2013-04-16 10:20:21

云存儲服務云存儲SLA服務水平協議

2010-11-08 13:54:49

Sqlserver運行

2023-10-13 00:09:20

桶排序排序算法
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区三区精品在线 | 国产91在线观看 | 91丨九色丨国产在线 | 国产精品久久久久久久久 | 日韩在线观看一区二区三区 | 成人h免费观看视频 | 国产黄色在线 | 91国语清晰打电话对白 | 国产aa| aⅴ色国产 欧美 | 亚洲视频自拍 | 草久网 | 欧美精品三区 | 日本一二区视频 | 国产中文字幕在线观看 | 亚洲精品成人av久久 | 天天看天天操 | 日韩午夜场 | 欧美婷婷 | 91久久精品日日躁夜夜躁国产 | 在线观看日韩精品视频 | 91久久国产综合久久 | 亚洲精品在线免费播放 | 国产成人免费 | 久久男人 | 五月婷婷 六月丁香 | 99资源站| 日韩乱码在线 | 欧美综合视频在线 | 91亚洲国产成人久久精品网站 | 日本三级电影在线看 | 777zyz色资源站在线观看 | 亚洲欧美视频一区二区 | 色成人免费网站 | 成人亚洲精品 | 国产激情小视频 | 欧洲一区二区在线 | 看特级黄色片 | 成人一区二区三区视频 | 国产成人av电影 | 亚洲国产成人av好男人在线观看 |