前端SSR和ssg区别

前端里的 SSR(Server-Side Rendering)SSG(Static Site Generation) 本质都是"提前把页面 HTML 准备好",但它们的生成时机和适用场景完全不同


一句话区别

  • SSR:每次请求都在服务器实时生成 HTML

  • SSG:构建时一次性生成 HTML,之后直接复用


1. SSR(服务端渲染)

工作方式

用户请求页面 → 服务器执行前端代码 → 生成 HTML → 返回浏览器

特点

  • 每次请求都会执行一次渲染

  • 可以拿到最新数据

  • 首屏速度快(比纯 CSR 好)

  • 服务器压力较大

适用场景

  • 数据强实时性(如订单、用户中心)

  • SEO 要求高 + 内容经常变化

  • 权限相关页面(根据用户不同渲染不同内容)

举例

比如电商商品页库存实时变化,就适合 SSR


2. SSG(静态生成)

工作方式

构建阶段(build)就把页面 HTML 生成好 → 部署 → 用户直接拿静态文件

特点

  • 不需要服务器实时计算

  • 极快(CDN 直接返回 HTML)

  • 成本低、稳定性高

  • 数据不是实时的(需要重新 build 或增量更新)

适用场景

  • 内容不常变

  • 强 SEO(博客、官网、文档)

  • 营销页面

举例

博客文章、官网介绍页


3. 核心对比

维度 SSR SSG
生成时机 请求时 构建时
数据实时性
性能 中(依赖服务器) 极高(CDN)
成本
SEO
适合场景 动态数据 静态内容

4. 框架里的体现(你做前端会很常见)

React生态

  • SSR:Next.js 的 getServerSideProps

  • SSG:Next.js 的 getStaticProps

Vue生态

  • SSR:Nuxt 的 server 模式

  • SSG:Nuxt 的 generate / nuxt build --prerender


5. 实际开发中的一个关键认知

很多项目不是二选一,而是混合模式(Hybrid Rendering)

  • 首页:SSG(快)

  • 商品页:SSR(实时)

  • 用户页:CSR(纯前端)

像 Next.js / Nuxt 现在都是这种"按页面选择渲染策略"。


6. 一个更本质的理解

你可以这样记:

  • SSR = "每次现做一份热菜"

  • SSG = "提前做好盒饭直接发"

相关推荐
一点一木2 小时前
深度体验TRAE SOLO移动端7天:作为独立开发者,我把工作流揣进了兜里
前端·人工智能·trae
天外飞雨道沧桑3 小时前
TypeScript 中 omit 和 record 用法
前端·javascript·typescript
yyyyy_abc3 小时前
ceph学习笔记
笔记·ceph·学习
Lee川3 小时前
mini-cursor 揭秘:从 Tool 定义到 Agent 循环的完整实现
前端·人工智能·后端
晓梦林3 小时前
ximai靶场学习笔记
android·笔记·学习
weelinking3 小时前
【产品】00_产品经理用Claude实现产品系列介绍
数据库·人工智能·sql·数据挖掘·github·产品经理
nashane3 小时前
HarmonyOS 6学习:外接键盘CapsLock与长截图功能的实战调试与完整解决方案
学习·华为·计算机外设·harmonyos
Agent产品评测局3 小时前
制造业模具管理AI系统,主流产品能力对比详解:2026年智能制造选型深度洞察
人工智能·ai·chatgpt·制造
canonical_entropy4 小时前
从 Spec-Driven Development 到 Attractor-Guided Engineering
前端·aigc·ai编程
研☆香4 小时前
聊聊前端页面的三种长度单位
前端