」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 掌握 Next.js 中的 SSR:如何提升 SEO 與使用者體驗

掌握 Next.js 中的 SSR:如何提升 SEO 與使用者體驗

發佈於2024-11-14
瀏覽:207

Mastering SSR in Next.js: How to Boost SEO and User Experience

SSR(伺服器端渲染)是 Next.js 中產生頁面的另一種方法。在本文中,我想解釋什麼是 SSR、它是如何運作的,以及如何在 Next.js 專案的 Page Router 和 App Router 中實現它。

什麼是SSR?

SSR是一種在使用者發出請求後產生靜態頁面(或預先渲染頁面)的方法。這意味著每次請求都會產生一個靜態頁面。此方法對於需要經常更新的頁面很有用,因為它可以確保資料始終是新鮮的

SSR 如何運作?

當您在Next.js中使用SSR時,每次使用者要求實作了SSR的頁面時,都會在發出請求後產生該頁面。這意味著使用者必須等待 Next.js 為每個請求再次產生並捆綁靜態內容。靜態頁面準備好後,使用者就可以看到要求的頁面。

需要注意的是,SSR僅在伺服器上運行,並且它會為每個請求產生一個靜態頁面,因此它不會在專案的建置過程中運行。

如何在 App Router 中實現 SSR

要在 App Router 中實作 SSR,您不需要編寫特殊函數或設定特定配置,因為它在您的伺服器元件中預設為啟用。

例如,如果您有一個靜態頁面並從 API 獲取數據,則該頁面將預設使用 SSR。需要注意的是,當使用 SSR 時,頁面不會在建置時捆綁或預先渲染。如果您在專案中使用動態頁面,如果您不取得任何數據,它將預設使用 SSG。但是當您從 API 取得時,它將切換到 SSR,並且在建置期間不會捆綁任何靜態頁面。

這是在靜態路由中實作SSR的範例:

import React from 'react';

const AboutPage = async () => {
  // Fetch data from an API or any server-side source
  const data = getDataFromApi();

  return (
    

About Us

{data}

); }; export default AboutPage;

如何在頁面路由器中實現 SSR

要在頁面路由器中實作 SSR,您需要在檔案中建立 getServerSideProps 函數。該函數將在每次用戶請求後調用。如果您使用動態路由,例如 [id] 文件,則還需要在文件中使用 getServerSideProps。此函數採用一個參數,通常稱為 context,您可以從中檢索 id,即動態頁面的值。伺服器在每次用戶請求時都會呼叫此函數。

這是在 tsx 檔案中實現的範例:

import { GetServerSideProps } from 'next';

interface AboutProps {
  data: string;
}

const AboutPage: React.FC = ({ data }) => {
  return (
    

About Us

{data}

); }; // This function runs on the server on every request export const getServerSideProps: GetServerSideProps = async () => { const data = getDataFromApi(); return { props: { data, }, }; }; export default AboutPage;

這是在 jsx 檔案中實作的範例:

const AboutPage = ({ data }) => {
  return (
    

About Us

{data}

); }; // This function runs on the server on every request export async function getServerSideProps() { const data = getDataFromApi(); return { props: { data, }, }; } export default AboutPage;

結論

SSR 是捆綁或建立靜態頁面的有用方法,但它不會在建置期間發生。當您需要根據每個使用者要求更新頁面以便使用者可以看到最新資料時,您可以使用 SSR。但是,需要注意的是,它可能需要更多時間,並且不如 SSG(靜態網站產生)或 ISR(增量靜態重新生成)等其他方法那麼快,因為它會為每個使用者請求產生一個靜態頁面。

希望您喜歡這篇文章!如果您有任何疑問,請隨時問我。如果您想了解 ISR 和 SSG,可以在此處查看我關於 ISR 和 SSG 的文章。如果你想了解更多,可以關注我的網站。

感謝您的閱讀!暫時再見!

版本聲明 本文轉載於:https://dev.to/saeedniyabati/mastering-ssr-in-nextjs-how-to-boost-seo-and-user-experience-1lmb?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-15
  • **如何在不停用索引的情況下最佳化 InnoDB 中的批次插入? **
    **如何在不停用索引的情況下最佳化 InnoDB 中的批次插入? **
    在InnoDB 中停用InnoDB 中最佳化批次插入的索引在嘗試停用InnoDB 表中的索引以增強批次插入效能時,您可能會遇到由於InnoDB 儲存引擎中缺少此功能而發出警告。以下是實現目標的替代策略:MySQL 參考建議:根據MySQL 文件的建議,考慮使用以下命令: SET 自動提交=0;SET...
    程式設計 發佈於2024-11-15
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1和$array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建構一...
    程式設計 發佈於2024-11-15
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-14
  • 如何使用命令式方法更新 React 中的巢狀狀態?
    如何使用命令式方法更新 React 中的巢狀狀態?
    更新嵌套狀態的命令式方法在 React 中,狀態更新是不可變的。這意味著要更新嵌套物件或數組,您不能簡單地修改其屬性並期望變更反映在 UI 中。相反,您需要建立包含更新值的新物件或數組,然後將其傳遞給 setState。 考慮以下範例,其中我們要更新物件中索引 1 處的物件的 name 屬性儲存在狀...
    程式設計 發佈於2024-11-14
  • 原子變數有哪些不同的記憶體排序模型?
    原子變數有哪些不同的記憶體排序模型?
    瞭解記憶體排序的意思原子變數提供安全的記憶體存取和跨執行緒同步。了解不同的記憶體順序對於有效利用它們至關重要。 輕鬆:無記憶體同步。 可能重新排序的最佳化操作讀取和寫入。 順序一致 (seq_cst):最嚴格的排序。 防止對周圍的任何記憶體操作進行重新排序原子操作。 確保所有執行緒的記憶體存取一致。...
    程式設計 發佈於2024-11-14
  • 為什麼在 For 迴圈中放錯 Return 語句會影響輸入迴圈?
    為什麼在 For 迴圈中放錯 Return 語句會影響輸入迴圈?
    For循環中返回語句錯位在你的作業中,你遇到了一個問題,程式只允許輸入一隻寵物,儘管瞄準三個。這個問題源自於 make_list 函數中 return 語句的定位。 在 for 迴圈中,return 語句在到達函數時立即終止函數的執行。在提供的程式碼中,return 語句放置在循環內部,導致函數在第...
    程式設計 發佈於2024-11-14
  • 如何防止使用者關閉 Bootstrap 模式?
    如何防止使用者關閉 Bootstrap 模式?
    停用使用者啟動的 Bootstrap 模態退出您可以透過點選 Bootstrap 模態區域外部來阻止使用者關閉 Bootstrap 模態。這在您想要強制使用者在繼續操作之前與特定模態內容互動的情況下非常有用。 停用模態背景點擊關閉預設情況下,使用者可以透過點選模式視窗之外的任何位置來關閉模式。若要停...
    程式設計 發佈於2024-11-14
  • 如何在 Python 中將巢狀清單匯出到 CSV 檔案?
    如何在 Python 中將巢狀清單匯出到 CSV 檔案?
    在Python中將嵌套列表匯出到CSV檔案將嵌套列表(其中每個內部列表包含不同類型的元素)寫入CSV檔案可以在Python 中處理資料時這是一項常見任務。以下是應對這項挑戰的方法:Python 的 csv 模組提供了處理 CSV 作業的便利方法。若要將清單的清單(例如a = [[1.2,'a...
    程式設計 發佈於2024-11-14
  • 如何有效率地提取Go Slice的最後一個元素?
    如何有效率地提取Go Slice的最後一個元素?
    Go 提取切片最後一個元素的最佳方法在 Go 中使用切片時,有效操作元素至關重要。一個常見的任務是提取最後一個元素,這可以透過多種方法來實現。 現有解決方案的缺點使用切片提供的解決方案[len(slice)-1 :][0] 看起來很麻煩並且涉及不必要的複雜性。它會傳回一個僅包含最後一個元素的切片,然...
    程式設計 發佈於2024-11-14
  • 為什麼我的 JavaScript 事件在動態元素追加後沒有被觸發?
    為什麼我的 JavaScript 事件在動態元素追加後沒有被觸發?
    動態元素追加後 JavaScript 事件未觸發您遇到了向 DOM 追加新元素後 JavaScript 事件未觸發的問題。這是因為 jQuery 僅識別頁面載入期間最初執行時存在的元素。 要解決此問題,您需要使用事件委託來擷取動態元素中的事件。事件委託涉及擷取頁面載入期間已經存在的 DOM 中較高層...
    程式設計 發佈於2024-11-14
  • `unshift()` 是在 JavaScript 中將元素新增到陣列的最有效方法嗎?
    `unshift()` 是在 JavaScript 中將元素新增到陣列的最有效方法嗎?
    JavaScript 中的最佳數組前置將元素前置到數組的開頭是 JavaScript 中的常見要求。在這裡,我們探索一種比問題中建議的傳統方法更好的方法。 Unshift 方法:本機解決方案JavaScript 提供了一個名為 unshift 的內建方法有效地將元素新增至陣列的開頭。與涉及建立新陣列...
    程式設計 發佈於2024-11-14
  • 在 JavaScript 中透過建構函數定義方法是否會建立重複的函數副本?
    在 JavaScript 中透過建構函數定義方法是否會建立重複的函數副本?
    JavaScript 中透過原型與建構函數定義方法的效能影響在JavaScript 中,存在兩種建立具有公用函數的「類”的方法:使用原型或建構函數。方法 1 透過建構函式將函數指派給實例,而方法 2 利用原型在所有實例之間共用函數。 雖然方法 2 通常被認為更有效率,但剝奪實例的私有實例變數是一個顯...
    程式設計 發佈於2024-11-14
  • 如何使用 matcha.css 設定 HTML 樣式
    如何使用 matcha.css 設定 HTML 樣式
    Written by Emmanuel Odioko✏️ Matcha, a famous green tea, is known for its stress-reducing benefits. I wouldn't claim that this tea necessarily inspire...
    程式設計 發佈於2024-11-14
  • 如何在 PHP 中從物件數組中提取屬性列?
    如何在 PHP 中從物件數組中提取屬性列?
    從物件陣列中提取屬性列要從一行中的物件陣列中提取屬性列,我們可以使用PHP array_column()函數,在PHP 7.0 中引入。 $cats = Array( (object) ['id' => 15], (object) ['id' => 18], (o...
    程式設計 發佈於2024-11-14

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3