Vue 團隊正式開源 Rolldown:基于 Rust 的超快 JavaScrip 打包工具!
3 月 8 日,Vue 團隊正式開源了其對外公布已久的打包工具:Rolldown,它是使用 Rust 開發(fā)的 Rollup 替代品,提供了與 Rollup 兼容的 API 和插件接口,但在功能范圍上將更接近 Esbuild。本文就來詳細了解一下 Rolldown 背后的故事!
圖片
都有 Rollup 了,為什么還需要 Rolldown?
Rolldown 旨在成為 Vite 未來使用的核心底層打包工具,與常見的開箱即用的構建工具(如Webpack、Vite等)不同,它更加專注于底層的打包邏輯和核心功能,以滿足 Vite 對于高效打包的特定需求。
圖片
目前,Vite 的底層使用了兩個打包工具:
- Esbuild:Esbuild 是一款高性能的 JavaScript 打包器,專注于實現(xiàn)極速的構建過程。它支持多種模塊類型、語法轉換和插件擴展,且無需緩存即可迅速完成打包任務。在 Vite 中,Esbuild 被用于依賴預打包、TypeScript和JSX轉換、目標降級以及代碼壓縮。
- Rollup:Rollup 是一個JavaScript模塊打包器,能夠編譯小塊代碼成復雜的大型代碼塊,特別支持ES6模塊。它支持 Tree Shaking,有效去除未使用的代碼,減少最終文件大小。在 Vite 中,Rollup 被用于生產構建,并支持一個與Rollup 兼容的插件接口。
Vite 之所以采用兩個不同的打包工具,是因為雖然 Esbuild 速度卓越且功能豐富,但其在代碼塊拆分方面的局限使其不適用于應用打包;而 Rollup 雖在應用打包方面成熟可靠,但性能卻不及原生編譯工具。兩者各有優(yōu)勢,功能互補,因此 Vite 需要結合使用以滿足不同需求。
然而,使用兩個不同的打包工具存在明顯弊端:它們之間的輸出差異可能導致開發(fā)環(huán)境與生產環(huán)境行為的不一致,同時,用戶代碼在生產構建過程中會被多次解析、轉換和序列化,從而增加了不必要的性能開銷。
因此,希望 Vite 能夠整合一個單一的、性能卓越的打包工具,既能減少解析和序列化開銷,又能與 Rollup 插件生態(tài)兼容,并具備出色的大型應用構建輸出控制能力。所以,Rolldown 就誕生了!
正是在這個背景下,Rolldown 應運而生!
Rolldown 的未來
Rolldown 使用 Rust 編寫,并且使用了 Oxc 中的工具。Oxc 是字節(jié)跳動出品的一個用 Rust 編寫的 JavaScript 高性能工具集合,該項目的重點在于構建 JavaScript 的基本編譯器工具:解析器、linter、格式化程序、轉譯器、壓縮器和解析引擎。此外,OXC 還為 Rspack、Rolldown 和 Ezno 等新興 JavaScript 工具提供支持。
圖片
目前,Rolldown 主要依賴其高效的解析器和解析引擎進行工作。未來,一旦 Oxc 的轉換器和壓縮器可用,Rolldown 也將計劃集成它們,Rolldown 也將直接作為獨立的打包使用。
當 Rolldown 發(fā)展至成熟階段時,它將能夠直接取代 Esbuild 和 Rollup,這樣將減少了對外部工具的依賴,為未來的功能擴展提供更大的便利和靈活性。
注意:目前 Rolldown 仍處于積極研發(fā)階段,尚未達到生產環(huán)境的使用標準。
小結
Rolldown 可能是未來 5-10 年最具影響力的前端項目之一。
目前,Rollup 已成為業(yè)內領先的打包工具,其開創(chuàng)了 Tree Shaking 的概念。當 Vite 橫空出世,它亦以Rollup 為構建核心,成為多個主流框架的首選構建工具。Rollup 已經從單純的庫打包工具,演變?yōu)楝F(xiàn)代前端開發(fā)的核心支柱。
然而,隨著前端開發(fā)規(guī)模的擴張,Rollup 的性能瓶頸逐漸顯現(xiàn)。盡管 Esbuild 等使用 Go 編寫的原生打包工具速度飛快,但它們與 Rollup 并不兼容,且存在諸多局限,如缺乏 TypeScript 支持、 Tree Shaking限制等。Vite 試圖結合 Esbuild 與 Rollup 以獲得兩全其美的效果,但解析問題卻成為新的挑戰(zhàn)。每個構建工具都需要生成自己的 AST 樹,且眾多 Rollup/Vite 插件也重復進行解析,這無疑造成了資源浪費。
Rolldown 項目應運而生,旨在解決這些問題。它采用 Rust 語言編寫,這一語言以高效著稱,甚至在某些場景下超越了 Go 的性能。更重要的是,Rolldown 力求與 Rollup API 保持兼容,這將是一個巨大的突破。一旦成功,Vite 等框架可以無縫切換到 Rolldown,帶來顯著的性能提升。
更值得一提的是,Rolldown 還致力于實現(xiàn)單一解析的標準化。由于 Vite 的廣泛應用和 Rolldown 采用 OXC 進行解析,我們有望看到一個以單一解析和 AST 樹標準化為核心的新時代。這將為開發(fā)環(huán)境和構建時間帶來前所未有的性能飛躍。
展望未來,若 Rolldown 能夠成功實現(xiàn)這些目標,它將成為轉換每一個代碼字節(jié)的關鍵引擎,無論開發(fā)者選擇何哪個框架。Rolldown 的出現(xiàn),無疑將為前端開發(fā)領域帶來一場深刻的變革。
相關鏈接
- Rolldown 官網:https://rolldown.rs/
- Rolldown GitHub 倉庫:https://github.com/rolldown-rs/rolldown