在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

打包工具Rolldown 1.0.0-beta.1發布

OSC開源社區 ? 來源:OSC開源社區 ? 2024-12-31 10:00 ? 次閱讀

Rolldown 1.0.0-beta.1 發布了。

Rolldown 是使用 Rust 開發的 Rollup 替代品,它提供與 Rollup 兼容的應用程序接口和插件接口,但在功能范圍上更類似于 esbuild。

作為一款現代化的打包工具,Rolldown 為開發者提供了更高效、便捷的開發體驗。

Rolldown 是尤雨溪公司投資的 Vite 基建開源項目,采用 Rust 從零開始構建了一個 API 與 Rollup 兼容的 JavaScript 打包器。

下文來自Rolldown 官方博客:《我們為什么需要打包器?》

01. 打包有用論

現代瀏覽器普遍支持原生 ESM 模塊和 HTTP/2,所以部分開發者提倡即使在生產環境中,也采用非打包方案(unbundled)來發布 Web 應用。

但 Rolldown 團隊認為,這種方案只適用小型應用,對于關注用戶體驗的性能敏感型應用,打包器仍不可或缺。

現代前端開發中,試圖跳過構建步驟仍然不切實際。即使在完善的非打包部署模型中,構建步驟通常也無法避免。

舉個栗子,Rails 8 默認的基于導入映射方案:所有 JS 資源仍需要構建,以便對資源指紋識別,并生成導入映射和模塊預加載指令。這只是通過 importmap-rails 來“曲線救國”,從而不直接使用 JS 打包器。

此外,對于下列需求,非打包方案存在缺陷:

使用現代 JS 特性,比如 ES6+、TS 或 JSX。

使用打包器專屬的優化,比如 tree-shaking(樹搖)、代碼分割或壓縮。

使用依賴構建的庫或框架。

發布源碼未打包的 npm 依賴,導致請求過多。

JS 打包無用論的主要論點是構建時增加了復雜性,減慢了開發反饋循環。

02. 三大優化

本質上,打包器的存在是因為 Web 應用的獨特限制:它們需要通過網絡按需交付。

打包器可以通過三大方案來提高 Web 應用的性能:

1、減少網絡請求和 waterfall(瀑布量)。 2、減少通過網絡發送的總字節數。 3、提高 JS 的執行性能。

03. 減少網絡請求

首先,使用 HTTP/2 協議并不意味著可以不再關心請求數量。

盡管 HTTP/2 理論上支持無限多路復用,但瀏覽器/服務器對每個連接最大并發流數量的默認限制大約為 100。

每個網絡請求在服務器和客戶端上都有固定開銷,比如請求頭處理、TLS 加密、多路復用等。更多請求意味著更多服務器負載,而實際并發性受限于服務器提供模塊文件的速度。

即使使用 HTTP/2,包含數千個未打包模塊的應用仍然會導致嚴重的網絡瓶頸。

深度導入鏈還會導致網絡瀑布(waterfall),即瀏覽器需要多次網絡往返才能獲取整個模塊圖。

這可以在通過 modulepreload 指令來稍微緩解,但是生成這些指令需要工具支持,并且在標簽中使用數千個 modulepreload 指令會導致 HTML 本身膨脹,這又是另一個性能問題。

打包可以通過將數千個模塊組合成服務器和瀏覽器都可以輕松處理的最佳數量的 chunk(組件塊),減少此類開銷。

打包還可以拍平導入鏈深度來減少 waterfall,并且可以提供生成 modulepreload 指令所需的數據。

本質上,打包將組合模塊圖的工作移到構建時,而不是為每個訪問者帶來運行時成本。這使得大型應用在網絡較差時,初次訪問的加載速度也能顯著加快。

3.1 緩存策略的權衡

打包無用論的另一個觀點是,非打包方案允許單獨緩存每個模塊,減少更新應用時緩存失效的數量。

然而,如上所述,這樣做的代價是降低了初始加載速度。

次優的打包配置可能會導致級聯塊哈希驗證,導致用戶在應用更新時必須重新下載應用的主要內容。

但這問題不大:打包器還可以利用導入映射和高級分塊控制,限制哈希無效并提高緩存命中率。

Vite / Rolldown 計劃會提供改進的、緩存更友好的默認分塊策略。

04. 減少總字節數

打包還可以減少網絡發送的 JS 體積。

首先,打包可以將多個模塊提升到同一作用域,移除其中所有 import / export 語句。

其次,tree-shaking(消除死代碼)是一種能且僅能通過靜態分析源碼來執行的構建時優化。

原生 ESM 會及早加載和執行所有內容,因此即使你只使用大模塊的單個導出,也必須下載并執行整個模塊。智能打包器可以從最終打包中移除未使用的 export,節省大量字節。

最后,在打包代碼上執行壓縮和 gzip 時,比單個模塊效率更高。

綜上所述,打包既可以減少用戶下載的代碼,也可以減少服務器使用的帶寬。

05. 提高 JS 執行性能

JS 是一種解釋型語言,現代 JS 引擎通常采用先進的 JIT 編譯來提升運行速度。然而,解析和編譯 JS 的成本也不低。

發送更少的 JS 代碼不僅可以節省帶寬,還意味著在瀏覽器中編譯和執行的 JS 更少,應用的啟動時間更短。

一些打包器/壓縮器還可以執行諸如常量折疊/AOT(及早執行)之類的優化,使打包代碼比手寫的源碼更高效。

高潮總結

由于 Web 應用依賴于網絡交付,前端目前仍然需要一個高性能的打包器。

打包器起碼有三大方案來優化性能,Rolldown 以 Vite 用戶為起點,可以提供更加一致的打包體驗,同時性能又比肩 esbuild + rollup。

來源:尤大為什么要投資打包器,Rolldown 公測版發布

閱讀更多

前端開始“銹化”?Vue團隊開源JS打包工具:基于Rust、速度極快、尤雨溪主導 最受歡迎前端框架——Vue創始人尤雨溪成立新公司VoidZero:聲稱打造下一代JavaScript工具鏈、已融資3200萬

Vue誕生10年,創始人尤雨溪推動“銹化”——通過Rust提升Web基礎設施性能

相關來源

https://x.com/rolldown_rs/status/1871953492979617976 https://github.com/rolldown/rolldown/releases/tag/v1.0.0-beta.1 https://rolldown.rs/guide/in-depth/why-bundlers https://mp.weixin.qq.com/s/okYoOQXN9Emo1kjfNXqpnQ https://mp.weixin.qq.com/s/i3MdBCwCBCG2Wue0ud1h7w

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • javascript
    +關注

    關注

    0

    文章

    525

    瀏覽量

    54578
  • Rust
    +關注

    關注

    1

    文章

    233

    瀏覽量

    6996

原文標題:這款“銹化”的開源JS打包工具發布1.0 Beta——性能強勁、尤雨溪主導

文章出處:【微信號:OSC開源社區,微信公眾號:OSC開源社區】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    PCBA包工包料:用專業力量為企業生產“減負增效”

    一站式PCBA加工廠家今天為大家講講什么是PCBA包工包料服務?PCBA包工包料服務的優勢。隨著電子制造行業的快速發展,越來越多的企業選擇PCBA包工包料服務,以降低成本、提高生產效率,專注于
    的頭像 發表于 05-26 09:34 ?132次閱讀

    雷軍官宣小米發布會:首款SUV將亮相 雷軍官宣小米YU7發布時間

    雷軍官宣小米YU7發布時間在22號,雷軍發文稱:小米戰略新品發布會,定在5月22日晚7點。 這次重磅新品特別多:手機SoC芯片小米玄戒o1,小米15SPro,小米平板7 Ultra,小米首款SUV
    的頭像 發表于 05-19 16:42 ?449次閱讀

    重磅更新 | 先楫半導體HPM_APPS v1.9.0發布

    重磅更新 | 先楫半導體HPM_APPS v1.9.0發布
    的頭像 發表于 05-13 11:29 ?349次閱讀
    重磅更新 | 先楫半導體HPM_APPS v1.9.0<b class='flag-5'>發布</b>

    中興通訊亮相2025對外承包工程行業發展大會

    近日,“2025對外承包工程行業發展大會暨中國對外承包工程行業發展論壇”在京舉辦,中興通訊高級副總裁孫方平受邀出席并發表了題為“數字筑基,生態共榮”的主旨演講,深入探討了數智化技術如何賦能海外傳統基礎設施建設,推動對外承包工程行
    的頭像 發表于 04-30 14:33 ?354次閱讀

    Linux文件系統打包及鏡像制作,觸覺智能RK3562開發板演示

    高達2.0GHz;內置獨立1Tops算力NPU,可應用于物聯網網關、平板電腦、智能家居、教育電子、工業顯示與控制等行業。工具獲取本文所介紹的方法需要使用到Linux
    的頭像 發表于 04-28 16:45 ?263次閱讀
    Linux文件系統<b class='flag-5'>打包</b>及鏡像制作,觸覺智能RK3562開發板演示

    先楫半導體HPM_SDK v1.7.0發布!這些更新你值得關注!

    先楫半導體HPM_SDK v1.7.0發布!這些更新你值得關注!
    的頭像 發表于 02-08 13:42 ?583次閱讀
    先楫半導體HPM_SDK v1.7.0<b class='flag-5'>發布</b>!這些更新你值得關注!

    Android16 Beta 1來襲,谷歌Pixel 6用戶搶先體驗

    提供的Android 16路線圖,Beta 1版本于2025年1發布Beta 2、Beta
    的頭像 發表于 01-24 10:36 ?941次閱讀

    谷歌計劃12月發布Gemini 2.0模型

    近日,有消息稱谷歌計劃在12月發布其下一代人工智能模型——Gemini 2.0。這一消息引發了業界的廣泛關注,因為谷歌在人工智能領域一直保持著領先地位,而Gemini系列模型更是其重要的產品之一。
    的頭像 發表于 10-29 11:02 ?1093次閱讀

    歡創播報 華為發布會撞期蘋果iPhone16發布

    1 華為發布會撞期蘋果iPhone16發布會 9月2日,華為宣布,其備受期待的品牌盛典及鴻蒙智行新品發布會將于9月10日舉行,屆時將展示華為的最新科技創新成果。華為消費者業務CEO余承
    的頭像 發表于 09-05 11:33 ?761次閱讀
    歡創播報  華為<b class='flag-5'>發布</b>會撞期蘋果iPhone16<b class='flag-5'>發布</b>會

    求助,關于open-loop反饋參數beta問題求解

    。 在closeloop中,beta是feedback factor,等于R1/(R1+Rf),是一個常數,請問在open loop中 1/be
    發表于 08-14 06:24

    AMD的銳龍9000系列處理器將延后至8月發布

    國際媒體傳來消息,AMD公司已正式向其全球合作伙伴宣布,原計劃于7月31日面世的銳龍9000系列處理器將延后至8月發布。這一調整源自于AMD在最終品質檢驗階段發現的首批生產批次未能全面符合其嚴苛的質量標準。
    的頭像 發表于 07-25 14:24 ?999次閱讀

    HPMicro Arduino支持包v0.1.0發布,適配功能揭曉!

    HPMicro Arduino支持包v0.1.0發布,適配功能揭曉!
    的頭像 發表于 07-11 08:18 ?830次閱讀
    HPMicro Arduino支持包v0.1.0<b class='flag-5'>發布</b>,適配功能揭曉!

    蘋果發布macOS 14.6 Beta 2

    。此次Beta 2的內部版本號為23G5061b,其緊隨前一版本發布僅兩周之后,如此緊湊的更新周期,無疑是在為macOS 14.x系列的最終完善以及向全新macOS 15 Sequoia系統的平穩過渡按下加速鍵。
    的頭像 發表于 07-02 11:10 ?1665次閱讀

    HarmonyOS NEXT Developer Beta1最新術語表

    A abc文件 方舟字節碼(ArkCompiler Bytecode)文件,是ArkCompiler的編譯工具鏈以源代碼作為輸入編譯生成的產物,其文件后綴名為.abc。在發布態,abc文件會被打包
    發表于 06-27 16:16

    HarmonyOS NEXT Developer Beta1中的Kit

    Kit工具箱的形式羅。 本文根據HarmonyOS NEXT Developer Beta1官方公開的開發文檔整理而成。
    發表于 06-26 10:47
    主站蜘蛛池模板: 五月深爱婷婷 | 免费看国产一级特黄aa大片 | 看逼网址| 国产资源免费观看 | sss欧美一区二区三区 | 怡红院精品视频 | 欧美三级在线视频 | 黄色日批网站 | 福利在线看片 | 性生大片一级毛片免费观看 | 五月婷婷爱| 色天天综合色天天看 | 91在线国内在线播放大神 | 爱爱视频天天看 | 在线观看免费观看 | 三及毛片 | 色婷婷综合久久久 | 精品久久久久久 | 动漫精品成人免费网站 | 春宵福利网站 | 一本大道加勒比久久综合 | 国产手机在线观看视频 | 亚洲人色大成年网站在线观看 | 轻点灬大ji巴太粗太长了爽文 | 亚洲色妞| 综合色影院 | 四虎影院海外永久 | 中文在线天堂网 | 免费黄色大片网站 | 色四虎| 性videofree极品另类 | 丁香花成人另类小说 | 午夜影院网站 | 女a男0攻巨肉高h | 欧美高清一级片 | 国产精品国产主播在线观看 | 国产二区三区 | 色色激情网 | 女色窝人体色77777 | 日本高清www | 天天干天天澡 |