Next.js 13.5 正式發佈,速度大幅提升!

来源:https://www.cnblogs.com/cuggz/archive/2023/09/23/17725397.html
-Advertisement-
Play Games

9 月 19 日,Next.js 13.5 正式發佈,該版本通過以下方式提高了本地開發性能和可靠性: 本地伺服器啟動速度提高 22%:使用App和Pages Router可以更快地進行迭代 HMR(快速刷新)速度提高 29%:在保存更改時進行更快的迭代 記憶體使用量減少 40%:在運行next sta ...


9 月 19 日,Next.js 13.5 正式發佈,該版本通過以下方式提高了本地開發性能和可靠性:

  • 本地伺服器啟動速度提高 22%:使用App和Pages Router可以更快地進行迭代

  • HMR(快速刷新)速度提高 29%:在保存更改時進行更快的迭代

  • 記憶體使用量減少 40%:在運行next start 時測量

  • 優化的包導入:使用流行的圖標和組件庫時進行更快的更新

  • next/image 改進:支持<picture>標簽、暗模式等

  • 修複了超過 438 個錯誤!

改善啟動和快速刷新時間

App Router 的採用在持續增加,根據 HTTP Archive 對前1000萬個網站進行的統計數據來看,其增長速度達到了每月 80%

圖片

image.png

自 Next.js 13.4 版本以來,Next.js 團隊的重點一直是改進 App Router 應用的性能和可靠性。將13.4與13.5版本進行比較,在一個新的應用上,可以看到以下改進:

  • 本地伺服器啟動速度提高 22%

  • HMR(快速刷新)速度提高 29%

  • 記憶體使用量減少 40%

通過以下優化方法實現了這種性能提升:

  • 通過緩存或減少慢速操作來減少工作量

  • 優化昂貴的文件系統操作

  • 在編譯過程中實現更好的增量樹遍歷

  • 將不必要的阻塞同步調用改為懶載入

  • 自動配置大型圖標庫

Next.js 用戶 Hanford 在他們的測試中報告了其編譯速度提升 87-92%!

圖片

image.png

在繼續迭代和改進當前打包工具性能的同時,Next.js 團隊還在開發 Turbopack(beta)以進一步提高性能。在13.5版本中,next dev --turbo現在支持更多功能。

優化的包導入

此版本對包導入進行了令人興奮的突破,改善了在使用大型圖標或組件庫以及其他重新導出了數百或數千個模塊的依賴項時的本地開發性能和生產冷啟動速度。

之前,添加了modularizeImports的支持,使開發者能夠配置在使用這些庫時如何解析導入。在13.5版本中,用optimizePackageImports替代了這個選項,它不需要指定導入映射,而是會自動優化導入。

@mui/icons-material@mui/materialdate-fnslodashlodash-esramdareact-bootstrap@headlessui/react@heroicons/react和lucide-react等庫現在都可以自動優化,只載入實際使用的模塊,同時方便編寫帶有很多命名導出的導入語句。

next/image 改進

基於社區的反饋,此版本添加了一個新的實驗性函數unstable_getImgProps(),以支持不直接使用<Image>組件的高級用例,包括:

  • 處理background-imageimage-set

  • 使用canvas的context.drawImage()new Image()時進行操作

  • 使用<picture>媒體查詢來實現藝術方向或明/暗模式圖片

  • 利用<picture>元素的媒體查詢功能,實現明/暗模式圖片的切換。

import { unstable_getImgProps as getImgProps } from 'next/image';

 

export default function Page() {

  const common = { alt: 'Hero', width: 800, height: 400 };

  const {

    props: { srcSet: dark },

  } = getImgProps({ ...common, src: '/dark.png' });

  const {

    props: { srcSet: light, ...rest },

  } = getImgProps({ ...common, src: '/light.png' });

 

  return (

    <picture>

      <source media="(prefers-color-scheme: dark)" srcSet={dark} />

      <source media="(prefers-color-scheme: light)" srcSet={light} />

      <img {...rest} />

    </picture>

  );

}

此外,現在placeholder屬性支持提供任意的data:image/作為占點陣圖像,這些圖像不會被模糊處理。

其他改進

自從13.4.0版本以來,我修複了超過438個錯誤,併進行了各種改進,包括:

  • [文檔] 關於表單和變異的新文檔

  • [文檔] 關於服務端和客戶端組件的新文檔

  • [文檔] 關於內容安全策略和非ces的新文檔

  • [文檔] 關於緩存和重新驗證的新文檔

  • [功能] 在頁面路由器中增加了對next/navigation中的useParamsuseSearchParams的支持,以便逐步採用

  • [功能] 在router.push / router.replace上支持scroll: false

  • [功能] 在next/link上支持scroll={false}

  • [功能] 開發環境支持HTTPS:next dev --experimental-https

  • [功能] 增加了對cookies().has()的支持

  • [功能] 增加了對IPv6主機名的支持

  • [功能] App Router現在支持Yarn PnP

  • [功能] 伺服器操作中添加了對redirect()的支持

  • [功能] 通過創建項目使用Bun的支持:bunx create-next-app

  • [功能] 中間件和邊緣運行時中的草稿模式支持

  • [功能] 現在中間件中支持cookies()headers()

  • [功能] Metadata API現在在Twitter卡片中支持summary_large_image

  • [功能] RedirectType現在從next/navigation導出

  • [功能] 添加了Playwright的實驗性測試模式

  • [改進] 重構了next start,能夠處理比之前多達1062%的請求量

  • [改進] 優化了Next.js內部以提高冷啟動性能(速度提升高達40%,在Vercel上測試)

  • [改進] 對App Router增強了Jest支持

  • [改進] 重新設計了next dev的輸出

  • [改進] 服務端操作現在與完全靜態路由一起工作(包括使用ISR重新驗證數據)

  • [改進] 服務端操作不再阻止路由之間的導航

  • [改進] 服務端操作不能再觸發多個併發操作

  • [改進] 調用redirect()的服務端操作現在將其推入歷史堆棧而不是替換當前條目,以確保返回按鈕正常工作

  • [改進] 服務端操作為防止瀏覽器緩存添加了no-cacheno-store cache-control

  • [改進] 修複了導航後可能調用兩次服務端操作的錯誤

  • [改進] 提高了對具有服務端組件的Emotion CSS的支持

  • [改進] 支持scroll-behavior: smooth用於哈希URL更改

  • [改進] 在所有瀏覽器中添加了Array.prototype.at的Polyfill

  • [改進] 修複了next dev緩存處理多個並行請求時可能發生的競爭條件

  • [改進] 控制臺中的fetch輸出現在顯示跳過緩存的請求(緩存:SKIP)

  • [改進] usePathname現在正確地去除了basePath

  • [改進] next/image現在在App Router中正確地預載入圖像

  • [改進] not-found不再兩次渲染根佈局

  • [改進] 現在可以克隆NextRequest(即new NextRequest(request)

  • [改進] app/children/page.tsx現在正確地處理文字/children路由

  • [改進] 內容安全策略現在支持預初始化腳本的nonce

  • [改進] 使用next/navigation中的重定向時現在支持basePath

  • [改進] 在Static Export中使用不受支持功能時改進了錯誤消息

  • [改進] 改進了遞歸readdir實現(速度提高了約3倍)

  • [改進] 修複了動態路由段中fallback:false之前引起的掛起請求問題

  • [改進] 修複了在請求已被取消時將信號傳遞給重新驗證請求導致請求失敗的錯誤

  • [改進] 刪除了404頁面上的fetch輪詢,改為使用websocket事件,避免在運行next dev時不必要的重新載入

  • [改進] performance.measure不再會導致水合不匹配

  • [改進] 修複了在編輯pages/_app時可能發生意外的完全重新載入的情況

  • [改進] ImageResponse現在擴展自Response,以改善類型檢查

  • [改進] 在next build中沒有頁面輸出時,不再顯示pages

  • [改進] 修複了在<Link>中忽略skipTrailingSlashRedirect的問題

  • [改進] 修複了開發模式下動態元數據路由重覆的問題


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 剛開始寫文章,封裝Base基類的時候,添加了trycatch異常塊,不過當時沒有去記錄日誌,直接return了。有小伙伴勸我不要吃了Exception 其實沒有啦,項目剛開始,我覺得先做好整體結構比較好。像是蓋樓一樣。先把樓體建造出來,然後再一步一步的美化完善。 基礎的倉儲模式已經ok,Autofa ...
  • 一:背景 1. 講故事 最近也挺奇怪,看到了兩起 CPU 爆高的案例,且誘因也是一致的,覺得有一些代表性,合併分享出來幫助大家來避坑吧,閑話不多說,直接上 windbg 分析。 二:WinDbg 分析 1. CPU 真的爆高嗎 這裡要提醒一下,別人說爆高不一定真的就是爆高,我們一定要拿數據說話,可以 ...
  • 簡介 Flurl是一個用於構建基於HTTP請求的C#代碼的庫。它的主要目的是簡化和優雅地處理網路請求(只用很少的代碼完成請求)。Flurl提供了一種簡單的方法來構建GET、POST、PUT等類型的請求,以及處理響應和異常。它還提供了一些高級功能,如鏈式調用、緩存請求結果、自動重定向等。本文將介紹Fl ...
  • 一、openKylin簡介 openKylin(開放麒麟) 社區是在開源、自願、平等和協作的基礎上,由基礎軟硬體企業、非營利性組織、社團組織、高等院校、科研機構和個人開發者共同創立的一個開源社區,致力於通過開源、開放的社區合作,構建桌面操作系統開源社區,推動Linux開源技術及其軟硬體生態繁榮發展。 ...
  • 簡介 NFS是Network File System的首字母縮寫。它是一種分散式協議,使客戶端可以訪問遠程伺服器上的共用文件。它允許網路中的電腦之間通過TCP/IP網路共用資源。 配置過程 安裝NFS服務端 sudo apt-get install nfs-kernel-server 遇到提示:輸 ...
  • 1.首先執行以下命令查看可安裝的jdk版本: yum -y list java* ​ 執行成功後可看到如下界面: 2.選擇自己需要的jdk版本進行安裝,比如這裡安裝1.8,執行以下命令: yum install -y java-1.8.0-openjdk-devel.x86_64 等待安裝完成即可。 ...
  • 職場經驗與見聞感悟 痞子衡在嵌入式行業也摸打滾爬了不少年,有一些個人經驗可以給大家參考。所謂他山之石可以攻玉,希望痞子衡的經驗對大家的職場之路有所幫助。 職場經驗篇(持續更新中...4/4) 職場上有效地向師傅請教問題的幾點建議 關於做技術的工作態度方面的幾點建議 工作多年的工程師且看這四條進階之路 ...
  • 在 Android 開發中,RxJava 2 是一個強大的非同步編程庫,提供了豐富的操作符來簡化數據流的處理。下麵是一些常用的 RxJava 2 操作符及其使用方法。 Observable.create(): 創建一個新的 Observable,可以在 subscribe() 方法中定義回調函數。 O ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...