Vite 的好與壞

全文 3000 字,歡迎點贊關注轉發

1、Vite 是什麼

2020年4月,尤大大發了這麼一個推:css

隨後,2021年2月,Vite 2.0 它來了,上來就是一套組合拳:html

  • 基於 esbuild 實現的極速開發體驗
  • 多框架支持
  • 兼容 Rollup 的插件機制與 API
  • SSR 支持
  • 舊瀏覽器支持

一開始我是拒絕的,從 grunt、gulp ,到 Webpack、Rollup、Snowpack 以及若干知名不知名構建框架,都2021了,還來?而後試用了一下,嗯,是真的香!前端

2、Vite 的優點

2.1 真 TM 快

Vite 很是很是快,對比 Vue-cli(基於 Webpack):vue

image.png

示例代碼:Vue3 項目,10個組件

測試二者的 dev 命令運行耗時相差十倍,且理論上,項目越大性能差距越大,爲何呢?最大的緣由是 Vite 在開發模式下並無作太多打包操做!react

Webpack 啓動後會作一堆事情,經歷一條很長的編譯打包鏈條,從入口開始須要逐步經歷語法解析、依賴收集、代碼轉譯、打包合併、代碼優化,最終將高版本的、離散的源碼編譯打包成低版本、高兼容性的產物代碼,這可滿滿都是 CPU、IO 操做啊,在 Node 運行時下性能必然是有問題。git

而 Vite 運行 Dev 命令後只作了兩件事情,一是啓動了一個用於承載資源服務的 service;二是使用 esbuild 預構建 npm 依賴包。以後就一直躺着,直到瀏覽器以 http 方式發來 ESM 規範的模塊請求時,Vite 纔開始「按需編譯」被請求的模塊。github

這裏 Vite 預設的前提是:vue-cli

  • 現代瀏覽器大多數已經原生支持 ESM 規範,構建工具 —— 特別是開發環境下已經沒有太大必要爲了低版本兼容把大量的時間花在編譯打包上了!

這麼一對比,Webpack 是啥都作了,瀏覽器只要運行編譯好的低版本(es5)代碼就行;而 Vite 只處理問題的一部分,剩下的事情交由瀏覽器自行處理,那速度必然賊 TM 快。npm

除了啓動階段跳過編譯操做以外,Vite 還有不少值得一提的性能優化,總體梳理一下:gulp

  • 預編譯:npm 包這類基本不會變化的模塊,使用 Esbuild 在 預構建 階段先打包整理好,減小 http 請求數
  • 按需編譯:用戶代碼這一類頻繁變更的模塊,直到被使用時纔會執行編譯操做
  • 客戶端強緩存:請求過的模塊會被以 http 頭 max-age=31536000,immutable 設置爲強緩存,若是模塊發生變化則用附加的版本 query 使其失效
  • 產物優化:相比於 Webpack ,Vite 直接錨定高版本瀏覽器,不須要在 build 產物中插入過多運行時與模板代碼
  • 內置更好的分包實現:不須要用戶干預,默認啓用一系列智能分包規則,儘量減小模塊的重複打包
  • 更好的靜態資源處理:Vite 儘可能避免直接處理靜態資源,而是選擇遵循 ESM 方式提供服務,例如引入圖片 import img from 'xxx.png' 語句,執行後 img 變量只是一個路徑字符串。

能夠看出,Vite 的快是全方位的,從 Dev 到 Build,從 npm 包到項目源碼,再到靜態資源處理都在 ESM 規則框架下儘量地實現各類優化措施,理論性能急劇提高。

2.2 簡單

Vite 的用法很簡單, 執行初始化命令:

yarn create @vitejs/app my-vue-app --template vue

就獲得了一個預設好的開發環境,能夠開始愉快地寫 demo 了,Vite 開箱就給你一堆功能,包括 css 預處理器、html 預處理器、hash 命名、異步加載、分包、壓縮、HMR 等:

這些功能,做者都按行業最佳實踐預設好了,一般不須要用戶介入作變動。

Vite 的表現很容易讓人聯想到 vue-cli,不過二者區別仍是挺大的:vue-cli 底層依賴 Webpack,實際的構建工做一般由各類 Webpack loader、plugin 實現,好比 less => css 由 less-loader 實現;圖片加載由 img-loader 實現等。這套設計很靈活,你能夠在 Webpack 體系下作任何你能想到的變動,只須要學習一點點 Webpack 的知識,包括百來個配置項、成千上萬的插件、若干虛無縹緲的構建概念等。

而 Vite 顯得特別簡潔,它只是暴露了極少數的配置項與 plugin 接口,設計上就沒打算讓你作太多自定義操做。。。這是由於 Vite 從一開始就沒打算作成另外一個 Webpack,而是作成一套「可以顯著提高前端開發體驗的前端構建工具」,重在 開發體驗 啊同窗們,Vite 可謂是用心良苦,想盡辦法下降學習入門成本,它就不但願你爲了使用工具又學一大堆複雜、縹緲的概念,但願這些事情都在框架層面屏蔽了 —— 雖然代價是喪失靈活性。

簡單說吧,Vite 定位就是傻瓜式但強大的構建工具,你專心寫好業務代碼,早點下班,不用再爲了工具費神費力了。

2.3 生態

除了極致的運行性能與簡易的使用方法外,Vite 對已有生態的兼容性也不容忽略,主要體如今兩個點:

  • 與 Vue 解耦,兼容支持 React、Svelte、Preact、Vanilla 等,這意味着 Vite 能夠被應用在大多數現代技術棧中
  • 與 Rollup 極其接近的插件接口,這意味着能夠複用 Rollup 生態中大部分已經被反覆錘鍊的工具

說真的,這兩條擺上桌面,加上前面討論的性能優點和超低學習成本,一時半會真想不到拒絕的理由了。。。

3、Vite 的劣勢

Vite 還很新,雖然它從理論與體感上提供了很是極致的開發體驗,仍是有一些值得關注的問題。

3.1 兼容性

默認狀況下,不管是 dev 仍是 build 都會直接打出 ESM 版本的代碼包,這就要求客戶瀏覽器須要有一個比較新的版本,這放在如今的國情下仍是有點難度的。

不過 Vite 同時提供了一些彌補的方法,使用 build.polyfillDynamicImport 配置項配合 [](https://github.com/vitejs/vit... \@vitejs/plugin-legacy 打包出一個看起來兼容性比較好的版本,我相信這一點會隨時間慢慢被抹平。

3.2 缺乏 Show Case

Vite 太新了,直到最近才釋放出正式 2.0版本,社區還沒太反應過來,天然也就沒什麼大型、複雜的商業落地案例,誰都說不許這裏面可能有多少坑。

不過好消息是社區對 Vite 的搜索熱度在最近幾個月急劇增加:

數據來自谷歌指數

相信很快就會出現一大批佈道者,畢竟這玩意兒是真的頗有競爭力。

3.3 代價

不要忘記,工程化自己的複雜度不會憑空消失,只 Vite 背後的團隊在幫咱們負重前行,這對 Vite 開發團隊而言,維護這麼多構建規則是一個不小的負擔。而站在用戶的角度,越容易上手的工具每每意味着越難被定製。

另外,若是隻是在 Vite 預設好的邊框裏面玩確實很容易,但隨着項目複雜度的提升,用戶早晚仍是會接觸到底層的 esbuild 或 Rollup,高工們該補的知識仍是早晚仍是得補回來,逃不掉的。

3、總結

Vite 給我最大的啓示:Webpack 並非標準答案,前端構建工具能夠有一些新的玩法:

  • 打包 不是目的,運行 纔是,2021年了,可以交給瀏覽器作的事情就交給瀏覽器吧
  • 一個靈活的框架,對做者而言可能意味着逐步失控的開發量;對用戶而言可能意味高學習成本,以及不斷重複的相似空格好仍是 tab 好的爭論。那麼,一套內置好各類業界 最佳實踐,沒有太多定製空間的工具,某些狀況下反而能提高你們的效率

我我的對 Vite 的態度:短時間保持觀望,長期很是看好。

我相信如今開始上手學習 Vite 是一個不錯的選擇,這東西封裝的太好了,學習成本極低(吹逼效果極好),能夠寫點 Demo 或者就直接在一些用戶範圍可控的小型新項目落地。可是,建議不要激進地直接重構一些已有的大型項目,別本身給本身埋坑了,早點下班不香嗎。

相關文章
相關標籤/搜索