0

0

何时在 Nextjs 中使用 SSR 和 SSG

霞舞

霞舞

发布时间:2025-01-09 15:39:32

|

641人浏览过

|

来源于php中文网

原创

何时在 nextjs 中使用 ssr 和 ssg

服务器端渲染 (SSR)静态站点生成 (SSG) 是 Next.js 提供的两种强大的页面渲染模式,选择哪种模式取决于您的应用需求。

SSR (服务器端渲染):

SSR 在每次用户请求页面时,都会在服务器端动态生成 HTML。这意味着每次访问页面,服务器都会获取最新数据并渲染页面,然后将完整的 HTML 发送给客户端浏览器。

SSR 的优点在于内容始终是最新的,非常适合需要实时数据的应用,例如:

  • 动态内容频繁更新的网站
  • 需要个性化内容的应用 (例如,基于用户登录状态显示不同的内容)
  • 依赖于实时数据库或 API 的应用

SSR 的缺点是服务器端处理开销较大,可能导致页面加载速度较慢。

SSR 时间线示例:

请求 1:用户 A 访问 → 服务器获取数据,动态生成页面,并响应。

请求 2:用户 B 访问 → 服务器再次获取数据,动态生成页面,并响应。

代码示例:

export async function getServerSideProps(context) {
  const res = await fetch(`https://api.example.com/data`);
  const data = await res.json();

  return {
    props: { data }, // 传递数据到页面组件
  };
}

function Page({ data }) {
  return 
{data.content}
; } export default Page;

SSG (静态站点生成):

SSG 在构建时 (例如,执行 next build 命令时) 预先渲染所有页面,并将生成的静态 HTML 文件存储在服务器上。当用户访问页面时,服务器直接提供这些预渲染的静态文件,无需任何服务器端处理。

Kotlin Android 中文开发帮助文档 PDF版
Kotlin Android 中文开发帮助文档 PDF版

这本书并不是一本语言参考书,但它是一个Android开发者去学习Kotlin并且使用在自己项目中的一个工具。我会通过使用一些语言特性和有趣的工具和库来解决很多我们在日常生活当中都会遇到的典型问题。 这本书是非常具有实践性的,所以我建议你在电脑面前跟着我的例子和代码实践。无论何时你都可以在有一些想法的时候深入到实践中去。 这本书适合你吗? 写这本书是为了帮助那些有兴趣 使用Kotlin语言来进行开发的Android开发者。 如果你符合下面这些情况,那这本书是适合你的: 你有相关Android开发和Andro

下载

SSG 的优点在于速度极快,因为页面直接从服务器提供静态文件,无需等待服务器端渲染。这非常适合内容变化不频繁的应用,例如:

  • 博客文章
  • 营销页面
  • 产品目录

SSG 的缺点是内容不是实时的,需要手动触发重新构建才能更新内容。 可以使用 revalidate 选项在后台定期重新生成页面,以确保内容的及时更新。

SSG 带有重新验证功能的时间线示例 (revalidate: 60 秒):

构建时间:页面使用构建时可用的数据进行预渲染。

请求 1 (构建后):用户 A 访问 → 提供静态 HTML。

后台重新生成 (60 秒后):Next.js 获取新数据并重新生成页面。

请求 2 (重新生成后):用户 B 访问 → 提供更新的静态 HTML。

代码示例:

export async function getStaticProps() {
  const res = await fetch('https://api.example.com/posts');
  const posts = await res.json();

  return {
    props: { posts },
    // 可选:每 60 秒重新生成页面
    revalidate: 60,
  };
}

function BlogPage({ posts }) {
  return (
    
{posts.map(post => (
{post.title}
))}
); }

总结:

特性 SSR SSG
渲染时机 每次请求时 构建时
内容更新 实时 构建时或重新验证时
速度 较慢 极快
适用场景 实时数据、个性化内容 静态内容、内容更新频率低
缓存 不适用,每次请求都生成新页面 适用,直接提供静态文件

选择 SSR 还是 SSG 取决于您的应用需求。如果需要实时数据,则选择 SSR;如果需要速度和性能,并且内容更新频率低,则选择 SSG。 对于内容更新频率适中的情况,可以考虑结合使用增量静态再生 (ISR) 等技术。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

512

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5306

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

481

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

Js中concat和push的区别
Js中concat和push的区别

Js中concat和push的区别:1、concat用于将两个或多个数组合并成一个新数组,并返回这个新数组,而push用于向数组的末尾添加一个或多个元素,并返回修改后的数组的新长度;2、concat不会修改原始数组,是创建新的数组,而push会修改原数组,将新元素添加到原数组的末尾等等。本专题为大家提供concat和push相关的文章、下载、课程内容,供大家免费下载体验。

218

2023.09.14

js截取字符串的方法介绍
js截取字符串的方法介绍

JavaScript字符串截取方法,包括substring、slice、substr、charAt和split方法。这些方法可以根据具体需求,灵活地截取字符串的不同部分。在实际开发中,根据具体情况选择合适的方法进行字符串截取,能够提高代码的效率和可读性 。

219

2023.09.21

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号