当前位置: 首页 > news >正文

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,提高感知性能,适用于大型页面或复杂应用。

相关文章:

  • @PostConstruct 注解的方法用于资源的初始化
  • HTML(12)——背景属性
  • 图解注意力
  • kafka的单机、集群部署安装
  • 如何看待鸿蒙HarmonyOS?
  • React.FC`<ChildComponentProps>`解释
  • 大型企业网络DHCP服务器配置安装实践@FreeBSD
  • 强化学习算法复现记录
  • 【大数据 复习】第3章 分布式文件系统HDFS(重中之重)
  • 刷题——二叉树的前序遍历
  • Java中如何处理日期和时间?
  • 哔哩哔哩视频URL解析原理
  • cocosCreator获取手机剪切板内容
  • 数据分类以及常见的数据格式
  • Simple-STNDT使用Transformer进行Spike信号的表征学习(三)训练与评估
  • JavaScript 如何正确处理 Unicode 编码问题!
  •  D - 粉碎叛乱F - 其他起义
  • iOS小技巧之UIImagePickerController实现头像选择
  • JSONP原理
  • Netty源码解析1-Buffer
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • TiDB 源码阅读系列文章(十)Chunk 和执行框架简介
  • webgl (原生)基础入门指南【一】
  • 闭包--闭包之tab栏切换(四)
  • 基于OpenResty的Lua Web框架lor0.0.2预览版发布
  • 批量截取pdf文件
  • 区块链共识机制优缺点对比都是什么
  • 思否第一天
  • 一道面试题引发的“血案”
  • 一个SAP顾问在美国的这些年
  • ​Java基础复习笔记 第16章:网络编程
  • ​LeetCode解法汇总307. 区域和检索 - 数组可修改
  • ​Linux Ubuntu环境下使用docker构建spark运行环境(超级详细)
  • ​sqlite3 --- SQLite 数据库 DB-API 2.0 接口模块​
  • ​ssh-keyscan命令--Linux命令应用大词典729个命令解读
  • #window11设置系统变量#
  • #多叉树深度遍历_结合深度学习的视频编码方法--帧内预测
  • $forceUpdate()函数
  • (CPU/GPU)粒子继承贴图颜色发射
  • (八)光盘的挂载与解挂、挂载CentOS镜像、rpm安装软件详细学习笔记
  • (二)Linux——Linux常用指令
  • (附源码)springboot人体健康检测微信小程序 毕业设计 012142
  • (每日持续更新)jdk api之FileReader基础、应用、实战
  • (四)React组件、useState、组件样式
  • (一)RocketMQ初步认识
  • (转)AS3正则:元子符,元序列,标志,数量表达符
  • (转)从零实现3D图像引擎:(8)参数化直线与3D平面函数库
  • (转)关于多人操作数据的处理策略
  • (轉貼) UML中文FAQ (OO) (UML)
  • .L0CK3D来袭:如何保护您的数据免受致命攻击
  • .Net Core webapi RestFul 统一接口数据返回格式
  • .NET上SQLite的连接
  • .vollhavhelp-V-XXXXXXXX勒索病毒的最新威胁:如何恢复您的数据?
  • /dev/sda2 is mounted; will not make a filesystem here!
  • /usr/bin/perl:bad interpreter:No such file or directory 的解决办法