iT邦幫忙

2023 iThome 鐵人賽

DAY 16
0
Modern Web

前端三兩事,哪些您必須要知道的事 !系列 第 16

Day 16 - React 「SSR Frameworks」分享

  • 分享至 

  • xImage
  •  

摘要

  • 這篇文章的目的是 ?
  • React 「SSR Frameworks」分享
  • 連結

這篇文章的目的是 ?

在現代網頁應用程式開發中,伺服器端渲染(Server-side rendering,簡稱SSR)框架扮演著重要的角色,它們可以幫助我們實現更快速、更具SEO優勢的網站。這篇文章的目的是為大家介紹SSR框架,特別關注於Next.js和Remix這兩個熱門框架,並提供程式碼範例以協助理解。

React 「SSR Frameworks」分享

什麼是SSR Frameworks?

SSR Frameworks是一類用於開發網頁應用程式的工具,它們允許我們在伺服器端生成網頁內容,然後再將其傳送給瀏覽器進行顯示。這與傳統的客戶端渲染(Client-side rendering,簡稱CSR)不同,CSR是在瀏覽器中使用JavaScript來渲染網頁內容。SSR的主要優勢之一是它們可以提供更快速的首次加載時間,因為用戶在獲取HTML之前不需要等待JavaScript下載和執行。

SSR和CSR的差異

SSR和CSR之間的主要差異在於內容生成的位置。在SSR中,內容是在伺服器端生成的,然後傳送到瀏覽器。這使得搜索引擎更容易索引我們的網站,同時也有助於改善首次加載性能。相反,在CSR中,瀏覽器必須先下載JavaScript代碼,然後才能生成和顯示內容,這可能會導致較長的加載時間和較差的SEO。

Next.js

Next.js是一個流行的React框架,它為我們提供了一個簡單而強大的方式來實現SSR。下面是一個簡單的Next.js示例:

首先,安裝Next.js:

bashCopy code
npm install next react react-dom

接下來,創建一個名為**pages/index.js**的文件,並添加以下代碼:

javascriptCopy code
import React from 'react';

function Home() {
  return (
    <div>
      <h1>歡迎來到Next.js SSR示例</h1>
    </div>
  );
}

export default Home;

然後,在終端中執行以下命令以啟動Next.js應用程序:

bashCopy code
npx next dev

現在,你可以在瀏覽器中訪問**http://localhost:3000**,看到你的首頁已經在伺服器端渲染。

Remix

Remix是另一個優秀的SSR框架,它提供了更多的靈活性和控制,同時也支援React。以下是一個簡單的Remix示例:

首先,安裝Remix:

bashCopy code
npm install @remix-run/react

然後,創建一個名為**routes/index.tsx**的文件,並添加以下代碼:

javascriptCopy code
import { json, LoaderFunction } from '@remix-run/react';

const loader: LoaderFunction = async () => {
  return json({ message: '歡迎來到Remix SSR示例' });
};

export default loader;

最後,在終端中執行以下命令以啟動Remix應用程序:

bashCopy code
npx create-remix@latest
npm run dev

現在,你可以在瀏覽器中訪問**http://localhost:3000**,看到你的首頁已經在伺服器端渲染。

希望這篇文章能幫助你更好地理解SSR框架,以及如何使用Next.js和Remix來實現伺服器端渲染。這將有助於提升你的網站性能和SEO,為用戶提供更好的體驗。

連結

  • Next.js:https://nextjs.org/
  • Remix:https://remix.run/

上一篇
Day 15 - React「Forms」分享
下一篇
Day 17 - Storybook 分享
系列文
前端三兩事,哪些您必須要知道的事 !30
圖片
  直播研討會
圖片
{{ item.channelVendor }} {{ item.webinarstarted }} |
{{ formatDate(item.duration) }}
直播中

尚未有邦友留言

立即登入留言