WHAT - NextJS 系列之 Rendering - Server Rendering Strategies

2024-06-24 02:20

本文主要是介绍WHAT - NextJS 系列之 Rendering - Server Rendering Strategies,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1. Static Rendering(静态渲染)
    • 特点:
    • 实现方式:
  • 2. Dynamic Rendering(动态渲染)
    • 特点:
    • 实现方式:
  • 3. Streaming Rendering(流式渲染)
    • 特点:
    • 实现方式:
  • 总结

相关官方文档:https://nextjs.org/docs/app/building-your-application/rendering/server-components#server-rendering-strategies

There are three subsets of server rendering: Static, Dynamic, and Streaming.

在 React 和 Next.js 中,服务器端渲染(SSR)有三种主要的实现方式:Static RenderingDynamic RenderingStreaming Rendering。这些方式在处理数据获取、页面渲染和响应客户端请求的方式上有所不同。

1. Static Rendering(静态渲染)

静态渲染是在构建时(Build Time)生成 HTML 文件的过程。这种方式适用于内容较少变化的页面,如博客文章、产品展示等。

特点:

  • 预渲染:在构建应用时,所有需要的页面都已经生成好静态 HTML 文件。
  • 高性能:因为生成的页面在构建时就已经完成,不需要在每次请求时重新生成。
  • CDN 友好:静态页面可以轻松部署到 CDN 上,实现快速分发和加载。

实现方式:

在 Next.js 中,使用 getStaticPropsgetStaticPaths 可以实现静态渲染。

// pages/post/[id].js
import { useRouter } from 'next/router';export default function Post({ post }) {return (<div><h1>{post.title}</h1><p>{post.content}</p></div>);
}// 在构建时调用
export async function getStaticPaths() {const paths = [ /* 预生成的路径数组 */ ];return { paths, fallback: false };
}export async function getStaticProps({ params }) {const post = await fetchPostData(params.id);return { props: { post } };
}

2. Dynamic Rendering(动态渲染)

动态渲染是在每次请求时生成 HTML 的过程。这种方式适用于内容频繁变化或依赖用户输入的页面,如用户仪表盘、搜索结果等。

特点:

  • 实时数据:每次请求都会触发服务器端渲染,确保用户获取最新数据。
  • 灵活性高:适合需要频繁更新内容或个性化内容的场景。
  • 性能开销:每次请求都会占用服务器资源,因此需要考虑服务器性能和响应时间。

实现方式:

在 Next.js 中,使用 getServerSideProps 可以实现动态渲染。

// pages/dashboard.jsexport default function Dashboard({ data }) {return (<div><h1>Dashboard</h1><p>{data}</p></div>);
}// 每次请求都会调用
export async function getServerSideProps(context) {const data = await fetchDataForDashboard();return { props: { data } };
}

3. Streaming Rendering(流式渲染)

流式渲染是一种逐步发送 HTML 到客户端的渲染方式,这样客户端可以尽早看到部分内容,而无需等待整个页面渲染完成。适用于大型页面或复杂应用的优化。

特点:

  • 快速响应:客户端可以更早地开始解析和渲染部分内容,提高感知性能。
  • 渐进增强:逐步发送内容,使用户感觉页面加载速度更快。
  • 适合大页面:对于需要渲染大量内容的页面非常有效。

实现方式:

在 Next.js 中,使用 React 18 引入的 React.lazySuspense 组件,结合新的流式渲染支持,可以实现流式渲染。

// pages/index.js
import ClientComponent from '../components/ClientComponent';export default function Home() {return (<div><h1>Next.js Streaming Example</h1><ClientComponent /></div>);
}// components/ClientComponent.js
'use client';import React, { Suspense } from 'react';
const ServerComponent = React.lazy(() => import('./ServerComponent'));export default function ClientComponent() {return (<div><h1>Client Component</h1><Suspense fallback={<div>Loading...</div>}><ServerComponent /></Suspense></div>);
}// components/ServerComponent.js
import React from 'react';export default function ServerComponent() {// 模拟服务器端数据获取const data = new Promise((resolve) => {setTimeout(() => resolve('Server-side Data'), 3000);});return (<div><h1>Server Component</h1><p>{data}</p></div>);
}

在这个示例中,通过 SuspenseReact.lazy 实现流式渲染。当用户访问页面时,服务器会立即发送初始的 HTML,客户端在接收并解析后,可以逐步加载 ClientComponentServerComponent,使用户能够尽早看到部分内容。

总结

  • 静态渲染(Static Rendering):在构建时生成静态 HTML,适用于内容较少变化的页面。
  • 动态渲染(Dynamic Rendering):在请求时生成 HTML,适用于内容频繁变化的页面。
  • 流式渲染(Streaming Rendering):逐步发送 HTML,提高感知性能,适用于大型页面或复杂应用。

这篇关于WHAT - NextJS 系列之 Rendering - Server Rendering Strategies的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1088919

相关文章

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存

Windows Server 2025 搭建NPS-Radius服务器的步骤

《WindowsServer2025搭建NPS-Radius服务器的步骤》本文主要介绍了通过微软的NPS角色实现一个Radius服务器,身份验证和证书使用微软ADCS、ADDS,具有一定的参考价... 目录简介示意图什么是 802.1X?核心作用802.1X的组成角色工作流程简述802.1X常见应用802.

SQL Server身份验证模式步骤和示例代码

《SQLServer身份验证模式步骤和示例代码》SQLServer是一个广泛使用的关系数据库管理系统,通常使用两种身份验证模式:Windows身份验证和SQLServer身份验证,本文将详细介绍身份... 目录身份验证方式的概念更改身份验证方式的步骤方法一:使用SQL Server Management S

Spring AI 实现 STDIO和SSE MCP Server的过程详解

《SpringAI实现STDIO和SSEMCPServer的过程详解》STDIO方式是基于进程间通信,MCPClient和MCPServer运行在同一主机,主要用于本地集成、命令行工具等场景... 目录Spring AI 实现 STDIO和SSE MCP Server1.新建Spring Boot项目2.a

SQL Server中的PIVOT与UNPIVOT用法具体示例详解

《SQLServer中的PIVOT与UNPIVOT用法具体示例详解》这篇文章主要给大家介绍了关于SQLServer中的PIVOT与UNPIVOT用法的具体示例,SQLServer中PIVOT和U... 目录引言一、PIVOT:将行转换为列核心作用语法结构实战示例二、UNPIVOT:将列编程转换为行核心作用语

Spring Boot 整合 SSE的高级实践(Server-Sent Events)

《SpringBoot整合SSE的高级实践(Server-SentEvents)》SSE(Server-SentEvents)是一种基于HTTP协议的单向通信机制,允许服务器向浏览器持续发送实... 目录1、简述2、Spring Boot 中的SSE实现2.1 添加依赖2.2 实现后端接口2.3 配置超时时

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安