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查询数据库中有多少个表 sql server 数表:select count(1) from sysobjects where xtype='U'数视图:select count(1) from sysobjects where xtype='V'数存储过程select count(1) from sysobjects where xtype='P' SE

SQL Server中,always on服务器的相关操作

在SQL Server中,建立了always on服务,可用于数据库的同步备份,当数据库出现问题后,always on服务会自动切换主从服务器。 例如192.168.1.10为主服务器,12为从服务器,当主服务器出现问题后,always on自动将主服务器切换为12,保证数据库正常访问。 对于always on服务器有如下操作: 1、切换主从服务器:假如需要手动切换主从服务器时(如果两个服务

SQL Server中,isnull()函数以及null的用法

SQL Serve中的isnull()函数:          isnull(value1,value2)         1、value1与value2的数据类型必须一致。         2、如果value1的值不为null,结果返回value1。         3、如果value1为null,结果返回vaule2的值。vaule2是你设定的值。        如

SQL Server中,添加数据库到AlwaysOn高可用性组条件

1、将数据添加到AlwaysOn高可用性组,需要满足以下条件: 2、更多具体AlwaysOn设置,参考:https://msdn.microsoft.com/zh-cn/library/windows/apps/ff878487(v=sql.120).aspx 注:上述资源来自MSDN。

SQL Server中,用Restore DataBase把数据库还原到指定的路径

restore database 数据库名 from disk='备份文件路径' with move '数据库文件名' to '数据库文件放置路径', move '日志文件名' to '日志文件存放置路径' Go 如: restore database EaseWe from disk='H:\EaseWe.bak' with move 'Ease

JavaWeb系列二十: jQuery的DOM操作 下

jQuery的DOM操作 CSS-DOM操作多选框案例页面加载完毕触发方法作业布置jQuery获取选中复选框的值jQuery控制checkbox被选中jQuery控制(全选/全不选/反选)jQuery动态添加删除用户 CSS-DOM操作 获取和设置元素的样式属性: css()获取和设置元素透明度: opacity属性获取和设置元素高度, 宽度: height(), widt

C语言入门系列:探秘二级指针与多级指针的奇妙世界

文章目录 一,指针的回忆杀1,指针的概念2,指针的声明和赋值3,指针的使用3.1 直接给指针变量赋值3.2 通过*运算符读写指针指向的内存3.2.1 读3.2.2 写 二,二级指针详解1,定义2,示例说明3,二级指针与一级指针、普通变量的关系3.1,与一级指针的关系3.2,与普通变量的关系,示例说明 4,二级指针的常见用途5,二级指针扩展到多级指针 小结 C语言的学习之旅中,二级

BD错误集锦6——【IDEA报错】tomcat server功能无效,报错Java EE: EJB, JPA, Servlets

在网上查找原因,发现是非法关闭IDEA导致的。 Open Settings | Plugns and enable it. 在设置中enable JAVA EE和tomcat server即可。 参考: https://stackoverflow.com/questions/43607642/intellij-idea-plugin-errorproblems-found-loadin

JavaWeb系列六: 动态WEB开发核心(Servlet) 上

韩老师学生 官网文档为什么会出现Servlet什么是ServletServlet在JavaWeb项目位置Servlet基本使用Servlet开发方式说明快速入门- 手动开发 servlet浏览器请求Servlet UML分析Servlet生命周期GET和POST请求分发处理通过继承HttpServlet开发ServletIDEA配置ServletServlet注意事项和细节 Servlet注

C语言入门系列:初识函数

文章目录 一,C语言函数与数学函数的区别1,回忆杀-初中数学2,C语言中的函数 二, 函数的声明1,函数头1.1,函数名称1.2,返回值类型1.3,参数列表 2,函数体2.1,函数体2.2,return语句 三,main函数四,函数的参数与传递方式1,实参和形参1.1,函数定义(含形参)1.2,函数调用(使用实参) 2,参数传递方式2.1,值传递2.2,引用传递 五,函数原型与预声明1,