搜尋
首頁web前端js教程Next.js 中的 SSR 應用程式路由與頁面路由相比有何新變化

SSR in Next.js  What’s New in App Routing Compared to Page Routing

簡介

Next.js 長期以來一直是建立伺服器渲染 React 應用程式的流行選擇。憑藉其對伺服器端渲染 (SSR) 的內建支持,開發人員可以創建動態、SEO 友好的應用程式。然而,Next.js 13 中 App Router 的引入以及 Next.js 14 中的改進顯著簡化和增強了 SSR。

在這篇部落格文章中,我們將探討傳統頁面路由系統和較新的應用程式路由系統之間 SSR 的差異,重點介紹 SSR 的工作原理以及新路由範例如何對其進行更改。

頁面路由中的 SSR (Pre-Next.js 13)

在引入 App Router 之前,SSR 是在頁面路由系統中使用 getServerSideProps 等特定函數來處理的。每個請求都會呼叫此函數,允許開發人員在渲染頁面之前從伺服器端取得資料。

使用 getServerSideProps 的頁路由中的 SSR 範例:

export default function Blogs({ data }) {
  // Render the fetched data
  return (
    <div>
      {data.map((item) => (
        <div key="{item.id}">
          <h3 id="item-title">{item.title}</h3>
          <p>{item.content}</p>
        </div>
      ))}
    </div>
  );
}

// This function runs on every request
export async function getServerSideProps() {
  // Fetch data from an external API
  const res = await fetch('https://api.example.com/blogs');
  const data = await res.json();

  // Pass the data as props to the page component
  return { props: { data } };
}

這裡,getServerSideProps是Page Routing系統中SSR的關鍵。它允許您在每次請求時從 API(或任何其他資料來源)獲取數據,並將其作為 props 傳遞給頁面元件。這種模式雖然功能強大,但在處理大量伺服器端邏輯和不同的路由時可能會導致複雜的程式碼庫。

Next.js 中的應用程式路由和 SSR 14

在 Next.js 14 中,SSR 變得更加簡化並整合到應用程式路由系統中。這個新系統引入了伺服器元件和客戶端元件,其中 SSR 更加直觀。

在App Routing中,您現在可以直接取得元件內部的數據,而不需要像getServerSideProps這樣的特殊函數。您可以透過使用伺服器操作來實現此目的,這使得程式碼更簡單且更易於維護。

使用伺服器元件的應用程式路由中的 SSR 範例:

"use server";

export async function getBlogs() {
  try {
    const response = await fetch('https://api.example.com/posts');
    return response.json();
  } catch (error) {
    return { error: error.message };
  }
}

// This component runs on the server and fetches data
export default async function Blog() {
  const blogs = await getBlogs();

  return (
    <div>
      {(blogs || []).map((blog) => (
        <div key="{blog._id}">
          <h3 id="blog-name">{blog.name}</h3>
          <p>{blog.content}</p>
        </div>
      ))}
    </div>
  );
}

在此應用程式路由範例中,我們使用伺服器元件透過 use server 直接在元件檔案內取得資料。這樣就不再需要單獨的 API 路由或函數,例如 getServerSideProps.

伺服器操作的力量
Next.js 14 透過引入伺服器操作簡化了流程。這些操作可讓您直接取得和處理元件檔案中的數據,從而降低複雜性並使您的程式碼庫更易於維護。

伺服器操作的主要優點:

更簡潔的程式碼:您可以將所有內容保留在一個地方,而不是將伺服器端邏輯分散在單獨的檔案或函數中。
提高可維護性:移動部件更少意味著需要管理的程式碼更少,從而使您的應用程式更易於維護。
更好的效能:借助智慧型快取機制,您可以微調伺服器端邏輯以獲得最佳效能。

SSR in Next.js  What’s New in App Routing Compared to Page Routing

Next.js 中的水合作用

在 Next.js 和伺服器端渲染 (SSR) 的上下文中,水化是指將靜態渲染的 HTML 頁面(從伺服器發送)轉換為瀏覽器中完全互動式 React 應用程式的過程。它使用 React 的客戶端 JavaScript “水合”靜態 HTML,使頁面具有互動性。

應用程式路由與頁面路由中的水合

在頁面路由中,頁面上的每個元件都需要水合作用,使其在客戶端具有互動性。這意味著互動所需的所有 JavaScript 都會發送到客戶端,這可能會隨著應用程式的擴展而導致效能瓶頸。

在應用程式路由中,對於伺服器元件,只有客戶端元件(處理互動性的元件)被水化。這種選擇性水合作用減少了發送到客戶端的 JavaScript 量,從而提高了效能。

應用程式路由中的客戶端元件範例:

'use client';  // Mark this as a client component

export default function Button() {
  return (
    <button onclick="{()"> alert('Button clicked!')}>Click Me</button>
  );
}

這裡,按鈕組件被標記為帶有「use client」的客戶端組件。它允許交互並在客戶端運行,而其他非交互組件仍保留為伺服器組件,從而提高效能。

有關 App Routing 中水合作用的更多信息

其工作原理如下:

Parent Components as Server Components:

The parent components (usually the higher-level components or entire page components) are typically Server Components. They run on the server and handle things like data fetching, rendering static HTML, and passing that data down to child components.
Since these are server-rendered, they do not include any JavaScript on the client-side, and they are not interactive.

Client Components for Interactivity:

Child components, which handle interactivity (like buttons, forms, etc.), are Client Components. These components can use React hooks (useState, useEffect, etc.) and are hydrated on the client-side.
Server Components pass data to these Client Components via props.
Once the HTML is loaded in the browser, Next.js hydrates the Client Components, attaching the necessary event listeners and making the page interactive.

// Server Component (Parent Component)
export default async function ParentComponent() {
  // Fetch data on the server
  const data = await fetch('https://api.example.com/data').then(res => res.json());

  return (
    <div>
      <h1 id="This-is-Server-Side-Rendered">This is Server-Side Rendered</h1>
      <clientcomponent data="{data}"></clientcomponent>
    </div>
  );
}

// Client Component (Child Component)
'use client';

import { useState } from 'react';

function ClientComponent({ data }) {
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>Data from server: {JSON.stringify(data)}</p>
      <p>Client-side counter: {count}</p>
      <button onclick="{()"> setCount(count + 1)}>Increment</button>
    </div>
  );
}

Conclusion

Next.js 14 makes Server-Side Rendering (SSR) easier and more powerful with the introduction of server actions in the App Router. By allowing developers to fetch data directly inside component files, this new system streamlines server-side logic, simplifies codebases, and reduces the need for separate API routes. Coupled with selective hydration, SSR in Next.js 14 is now faster and more efficient, helping you build highly dynamic and SEO-friendly applications with ease.

By leveraging these server actions, you can improve your app’s performance while keeping your code clean and maintainable. The shift from Page Routing to App Routing with Server and Client Components represents a major leap forward in building scalable web applications.

SSR in Next.js  What’s New in App Routing Compared to Page Routing

以上是Next.js 中的 SSR 應用程式路由與頁面路由相比有何新變化的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
了解JavaScript引擎:實施詳細信息了解JavaScript引擎:實施詳細信息Apr 17, 2025 am 12:05 AM

理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。

Python vs. JavaScript:學習曲線和易用性Python vs. JavaScript:學習曲線和易用性Apr 16, 2025 am 12:12 AM

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

Python vs. JavaScript:社區,圖書館和資源Python vs. JavaScript:社區,圖書館和資源Apr 15, 2025 am 12:16 AM

Python和JavaScript在社區、庫和資源方面的對比各有優劣。 1)Python社區友好,適合初學者,但前端開發資源不如JavaScript豐富。 2)Python在數據科學和機器學習庫方面強大,JavaScript則在前端開發庫和框架上更勝一籌。 3)兩者的學習資源都豐富,但Python適合從官方文檔開始,JavaScript則以MDNWebDocs為佳。選擇應基於項目需求和個人興趣。

從C/C到JavaScript:所有工作方式從C/C到JavaScript:所有工作方式Apr 14, 2025 am 12:05 AM

從C/C 轉向JavaScript需要適應動態類型、垃圾回收和異步編程等特點。 1)C/C 是靜態類型語言,需手動管理內存,而JavaScript是動態類型,垃圾回收自動處理。 2)C/C 需編譯成機器碼,JavaScript則為解釋型語言。 3)JavaScript引入閉包、原型鍊和Promise等概念,增強了靈活性和異步編程能力。

JavaScript引擎:比較實施JavaScript引擎:比較實施Apr 13, 2025 am 12:05 AM

不同JavaScript引擎在解析和執行JavaScript代碼時,效果會有所不同,因為每個引擎的實現原理和優化策略各有差異。 1.詞法分析:將源碼轉換為詞法單元。 2.語法分析:生成抽象語法樹。 3.優化和編譯:通過JIT編譯器生成機器碼。 4.執行:運行機器碼。 V8引擎通過即時編譯和隱藏類優化,SpiderMonkey使用類型推斷系統,導致在相同代碼上的性能表現不同。

超越瀏覽器:現實世界中的JavaScript超越瀏覽器:現實世界中的JavaScriptApr 12, 2025 am 12:06 AM

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

使用Next.js(後端集成)構建多租戶SaaS應用程序使用Next.js(後端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:23 AM

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

如何使用Next.js(前端集成)構建多租戶SaaS應用程序如何使用Next.js(前端集成)構建多租戶SaaS應用程序Apr 11, 2025 am 08:22 AM

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具