next实现原理
Next.js 是一个基于 React 的 服务器端渲染(SSR) 和 静态生成(SSG) 框架,它的实现原理涉及多个关键技术点,包括 服务端渲染(SSR)、静态生成(SSG)、客户端渲染(CSR)、增量静态再生(ISR)、API 路由 等。
1. Next.js 核心实现原理
1.1. 页面预渲染(SSR 和 SSG)
Next.js 通过 预渲染(Pre-rendering) 提前生成 HTML,而不是像 React 传统的客户端渲染那样在浏览器中执行 JavaScript 后再渲染。
(1) 服务器端渲染(SSR)
- 函数:
getServerSideProps - 原理:
- 每次请求都会在服务器上执行
getServerSideProps,返回数据后再渲染 HTML。 - 适用于需要实时数据的页面(如用户个性化页面、动态数据请求)。
- 示例:
export async function getServerSideProps(context) {const res = await fetch('https://api.example.com/data');const data = await res.json();return { props: { data } }; } - 流程:
- 用户请求页面。
- Next.js 服务器执行
getServerSideProps获取数据。 - 服务器返回 HTML,浏览器解析并显示。
- 每次请求都会在服务器上执行
(2) 静态生成(SSG)
- 函数:
getStaticProps - 原理:
- 在 构建时(Build Time) 预先生成 HTML。
- 适用于数据不频繁变化的页面(如博客文章、文档)。
- 示例:
export async function getStaticProps() {const res = await fetch('https://api.example.com/data');const data = await res.json();return { props: { data } }; } - 流程:
next build阶段预渲染 HTML。- 访问时直接返回 HTML,速度极快。
(3) 增量静态再生(ISR)
- 函数:
getStaticProps+revalidate - 原理:
- 在 SSG 基础上,支持 定期重新生成 页面,不需要重新部署。
- 示例:
export async function getStaticProps() {const res = await fetch('https://api.example.com/data');const data = await res.json();return { props: { data }, revalidate: 10 }; // 10秒后重新生成 } - 流程:
- 初次访问使用缓存的 HTML。
- 过
revalidate时间后,Next.js 触发 后台再生(不会影响当前用户)。 - 重新生成 HTML 并更新缓存。
2. Next.js 的路由机制
2.1. 文件系统路由
- 通过
pages目录自动生成路由:pages/ ├── index.tsx # 访问 `/` ├── about.tsx # 访问 `/about` ├── blog/ │ ├── index.tsx # 访问 `/blog` │ ├── [id].tsx # 动态路由 `/blog/:id` - 动态路由:
原理:function BlogPost({ id }) {return <h1>Blog Post {id}</h1>; }export async function getStaticPaths() {return {paths: [{ params: { id: '1' } }, { params: { id: '2' } }],fallback: false,}; }export async function getStaticProps({ params }) {return { props: { id: params.id } }; }getStaticPaths预定义可能的路由。getStaticProps预取数据并生成静态页面。
3. 数据获取方式
Next.js 提供 四种 数据获取方式:
| 方法 | 执行时机 | 适用场景 |
|---|---|---|
getStaticProps | 构建时(Build Time) | 静态页面(如博客、文档) |
getServerSideProps | 请求时(Request Time) | 需要实时数据(如用户个性化页面) |
getStaticPaths | 构建时(Build Time) | 预定义动态路由(如博客详情) |
API 路由 (pages/api) | 服务器端 API | 处理后端请求,如数据库交互 |
4. API 路由
- Next.js 允许创建 API 端点,无需额外搭建后端:
pages/api/ ├── hello.ts # 访问 `/api/hello` - 示例:
export default function handler(req, res) {res.status(200).json({ message: "Hello from API" }); } - 应用:
- 作为 BFF(Backend For Frontend),连接数据库或第三方 API。
5. 中间层架构
Next.js 既可以:
- 作为 前端框架(纯前端渲染)。
- 作为 后端服务器(支持 API 和 SSR)。
- 通过 边缘计算(Edge Functions) 实现更快的响应。
6. Next.js 的优化
6.1. 自动代码拆分
- 只加载 当前页面 需要的代码,减少初次加载时间。
- 通过 动态导入(dynamic import) 进一步优化:
import dynamic from "next/dynamic"; const HeavyComponent = dynamic(() => import("../components/Heavy"), { ssr: false });
6.2. 图片优化
- 内置
next/image组件,自动 懒加载 和 CDN 加速:import Image from 'next/image';<Image src="/logo.png" width={200} height={100} alt="Logo" />
6.3. SEO 友好
next/head提供 自定义 Meta 标签:import Head from 'next/head';function HomePage() {return (<><Head><title>My Next.js App</title><meta name="description" content="Next.js is awesome!" /></Head><h1>Welcome to Next.js</h1></>); }
总结
| 功能 | Next.js 方案 | 作用 |
|---|---|---|
| SSR | getServerSideProps | 实时数据,适用于动态页面 |
| SSG | getStaticProps | 预渲染静态页面,适用于博客、文档 |
| ISR | revalidate | 静态+动态结合,适用于经常变更但无需实时的页面 |
| API | pages/api | 服务器端 API,后端功能 |
| 动态路由 | [id].tsx | 生成动态页面 |
| 图片优化 | next/image | 自动懒加载、CDN |
| 代码拆分 | dynamic import | 仅加载必要代码 |
Next.js 通过 SSR、SSG、ISR、API 路由等功能,大大提高了 渲染性能、SEO 友好性和开发体验,是现代 Web 开发的首选框架之一。 🚀
相关文章:
next实现原理
Next.js 是一个基于 React 的 服务器端渲染(SSR) 和 静态生成(SSG) 框架,它的实现原理涉及多个关键技术点,包括 服务端渲染(SSR)、静态生成(SSG)、客户端渲染…...
LeetCode 热题 100 53. 最大子数组和
LeetCode 热题 100 | 53. 最大子数组和 大家好,今天我们来解决一道经典的算法题——最大子数组和。这道题在 LeetCode 上被标记为中等难度,要求我们找出一个具有最大和的连续子数组,并返回其最大和。下面我将详细讲解解题思路,并…...
DeepSeek 与大数据治理:AI 赋能数据管理的未来
📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 1. 引言 在当今数字化时代,数据已成为企业和机构的重要资产,而大数据治理(Big Data Governan…...
【时时三省】(C语言基础)浮点型数据
山不在高,有仙则名。水不在深,有龙则灵。 ----CSDN 时时三省 浮点型数据 浮点型数据是用来表示具有小数点的实数的,为什么在C中把实数称为浮点数呢?在C语言中,实数是以指数正式存放在在储单元中的。一个实数表示为指数可以有不…...
【大模型】Ollama本地部署DeepSeek大模型:打造专属AI助手
【大模型】Ollama本地部署DeepSeek大模型:打造专属AI助手 Ollama本地部署DeepSeek大模型:打造专属AI助手一、Ollama简介二、硬件需求三、部署步骤1. 下载并安装Ollama(1)访问Ollama官网(2)安装Ollama 2. 配…...
2025.3.2机器学习笔记:PINN文献阅读
2025.3.2周报 一、文献阅读题目信息摘要Abstract创新点网络架构实验结论不足以及展望 一、文献阅读 题目信息 题目: Physics-Informed Neural Networks of the Saint-Venant Equations for Downscaling a Large-Scale River Model期刊: Water Resource…...
数据集笔记:新加坡 地铁(MRT)和轻轨(LRT)票价
数据连接 data.gov.sg 2024 年 12 月 28 日起生效的新加坡地铁票价 该数据集包含 MRT 和 LRT 票价的信息,包括: 票价类型(Fare Type):成人票、学生票、老年人票、残障人士票等。适用时间(Applicable Tim…...
如何修改安全帽/反光衣检测AI边缘计算智能分析网关V4的IP地址?
TSINGSEE青犀推出的智能分析网关V4,是一款集成了BM1684芯片的高性能AI边缘计算智能硬件。其内置的高性能8核ARM A53处理器,主频可高达2.3GHz,INT8峰值算力更是达到了惊人的17.6Tops。此外,该硬件还预装了近40种AI算法模型…...
Java 大视界 -- 基于 Java 的大数据分布式缓存一致性维护策略解析(109)
💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…...
SyntaxError: positional argument follows keyword argument
命令行里面日常练手爬虫不注意遇到的问题,报错说参数位置不正确 修改代码后,运行如下图: 结果: 希望各位也能顺利解决问题,祝你好运!...
Ruby基础
一、字符串 定义 283.to_s //转为string "something#{a}" //定义字符串,并且插入a变量的值 something//单引号定义变量 %q(aaaaaaaaa) // 定义字符串,()内可以是任何数,自动转义双引号%Q("aaaaa"…...
JMeter 断言最佳实践
JMeter 断言最佳实践 一、引言 在使用 JMeter 进行性能测试或功能测试时,断言是非常重要的一部分。断言可以帮助我们验证接口返回的结果是否符合预期,确保测试的准确性和可靠性。本文将介绍 JMeter 中常见的断言类型、使用这些断言的最佳实践ÿ…...
【Android】类加载器热修复-随记(二)
1. 背景 在【Android】类加载器&热修复-随记一文中了解了类加载,要完成完整的热修复过程,我们需要构建出差量jar包。而这构建差量包分为两个步骤: 原包,注解解析和插桩;变更后,差量包构建;在这两步过程中会涉及到较多的字节码操作,这里我们需要了解下。我们都听过…...
从零开始用react + tailwindcss + express + mongodb实现一个聊天程序(八) 聊天框用户列表
简单画了个聊天框 就是咱们的HomePage.jsx 1.后端接口开发 在server/src/index.js 新增 messagesRoutes 先引入 import messageRoutes from ./routes/message.route.js // 消息接口 app.use(/api/messages, messageRoutes) 在routes文件夹下新建message.route.js 有3个路…...
Linux网络 TCP全连接队列与tcpdump抓包
TCP全连接队列 在 Linux 网络中,TCP 全连接队列(也称为 Accept 队列)是一个重要的概念,用于管理已经完成三次握手,即已经处于 established 状态但尚未被应用程序通过 accept( ) 函数处理的 TCP 连接,避免因…...
水滴tabbar canvas实现思路
废话不多说之间看效果图,只要解决了这个效果水滴tabbar就能做出来了 源码地址 一、核心实现步骤分解 布局结构搭建 使用 作为绘制容器 设置 width=600, height=200 基础尺寸 通过 JS 动态计算实际尺寸(适配高清屏) function initCanvas() {// 获取设备像素比(解决 Re…...
鸿蒙通过用户首选项实现数据持久化
鸿蒙通过用户首选项实现数据持久化 1.1 场景介绍 用户首选项为应用提供Key-Value键值型的数据处理能力,支持应用持久化轻量级数据,并对其修改和查询。当用户希望有一个全局唯一存储的地方,可以采用用户首选项来进行存储。Preferences会将该…...
在Ubuntu中,某个文件的右下角有一把锁的标志是什么意思?
在Ubuntu中,某个文件的右下角有一把锁的标志是什么意思? 在 Ubuntu(或其他基于 GNOME 文件管理器的 Linux 发行版)中,文件或文件夹的右下角出现一把“锁”标志,通常表示 你当前的用户没有该文件/文件夹的写…...
7.1.1 计算机网络的组成
文章目录 物理组成功能组成工作方式完整导图 物理组成 计算机网络是将分布在不同地域的计算机组织成系统,便于相互之间资源共享、传递信息。 计算机网络的物理组成包括硬件和软件。硬件中包含主机、前端处理器、连接设备、通信线路。软件中包含协议和应用软件。 功…...
使用 Docker 部署 RabbitMQ 的详细指南
使用 Docker 部署 RabbitMQ 的详细指南 在现代应用程序开发中,消息队列系统是不可或缺的一部分。RabbitMQ 是一个流行的开源消息代理软件,它实现了高级消息队列协议(AMQP)。本文将详细介绍如何使用 Docker 部署 RabbitMQ…...
OpenLayers 可视化之热力图
注:当前使用的是 ol 5.3.0 版本,天地图使用的key请到天地图官网申请,并替换为自己的key 热力图(Heatmap)又叫热点图,是一种通过特殊高亮显示事物密度分布、变化趋势的数据可视化技术。采用颜色的深浅来显示…...
iOS 26 携众系统重磅更新,但“苹果智能”仍与国行无缘
美国西海岸的夏天,再次被苹果点燃。一年一度的全球开发者大会 WWDC25 如期而至,这不仅是开发者的盛宴,更是全球数亿苹果用户翘首以盼的科技春晚。今年,苹果依旧为我们带来了全家桶式的系统更新,包括 iOS 26、iPadOS 26…...
智慧医疗能源事业线深度画像分析(上)
引言 医疗行业作为现代社会的关键基础设施,其能源消耗与环境影响正日益受到关注。随着全球"双碳"目标的推进和可持续发展理念的深入,智慧医疗能源事业线应运而生,致力于通过创新技术与管理方案,重构医疗领域的能源使用模式。这一事业线融合了能源管理、可持续发…...
(十)学生端搭建
本次旨在将之前的已完成的部分功能进行拼装到学生端,同时完善学生端的构建。本次工作主要包括: 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...
黑马Mybatis
Mybatis 表现层:页面展示 业务层:逻辑处理 持久层:持久数据化保存 在这里插入图片描述 Mybatis快速入门 架构:x86_64 (GNU/Linux)Rust 版本:rustc 1.87.0 (2025-05-09)Cargo 版本:cargo 1.87.0 (2025-05-06) 2. 安装 Rust 2.1 使用 Rust 官方安…...
虚拟电厂发展三大趋势:市场化、技术主导、车网互联
市场化:从政策驱动到多元盈利 政策全面赋能 2025年4月,国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》,首次明确虚拟电厂为“独立市场主体”,提出硬性目标:2027年全国调节能力≥2000万千瓦࿰…...
