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

NextJS(ReactSSR)

pre-render: 预渲染

1. 静态化

发生的时间:next build

1). 纯静态化

2). SSG: server static generator

getStaticProps: 当渲染组件之前会运行 生成html + json

//该函数只可能在服务端运行
//该函数运行在组件渲染之前
//该函数只能在build期间运行
//返回的对象中的props属性,将被混合到整个组件属性
export async function getStaticProps() {const resp = await getMovies(1, 20);return {props: {movies: resp.data}};
}

getStaticPaths: 当渲染组件之前会运行 解决动态路由

//该函数用于得到有哪些可能出现的id
export async function getStaticPaths() {const resp = await getMovies();const paths = resp.data.map(m => ({params: {id: m._id}}));console.log("getStaticPaths");return {paths,fallback: true};
}

fallback:
false: 什么都不做,如果没有静态页面,返回404
true: 会给[id].html

什么时候要使用静态化:

如果你的页面不是根据不同的请求而展示不同,则推荐使用静态化

2. SSR: server side render 服务端渲染

根据每一次请求获取数据,进行渲染

// 每次请求到达后都会运行
// 仅在服务器端运行
// req, res, query
export async function getServerSideProps({ query }) {const page = +query.page || 1;console.log("getServerSideProps");const resp = await getMovies(page, 10);return {props: {movies: resp.data,page,total: resp.count,limit: 10}};
}
http://www.lryc.cn/news/3935.html

相关文章:

  • JointBERT代码复现详解【上】
  • 进程间通信(上)
  • 【Unity3D】Unity 3D 连接 MySQL 数据库
  • vue通用后台管理系统
  • IDEA设置只格式化本次迭代变更的代码
  • 算法训练——剑指offer(Hash集合问题)
  • Element UI框架学习篇(七)
  • 【项目实战】32G的电脑启动IDEA一个后端服务要2min!谁忍的了?
  • 2022年山东省中职组“网络安全”赛项比赛任务书正式赛题
  • RibbitMQ 入门到应用 ( 二 ) 安装
  • 提取DataFrame中每一行的DataFrame.itertuples()方法
  • 基于卷积神经网络的立体视频编码质量增强方法_余伟杰
  • 【2023unity游戏制作-mango的冒险】-3.基础动作和动画API实现
  • 跨域的几种解决方案?
  • 2022年山东省职业院校技能大赛网络搭建与应用赛项正式赛题
  • 【JUC并发编程】ArrayBlockingQueue和LinkedBlockingQueue源码2分钟看完
  • GitHub个人资料自述与管理主题设置
  • Express篇-连接mysql
  • win10 安装rabbitMQ详细步骤
  • 【成为架构师课程系列】一线架构师:6个经典困惑及其解法
  • 光耦合器的定义与概述
  • 谷粒商城--品牌管理详情
  • stack、queue和priority_queue
  • 面试题(二十二)消息队列与搜索引擎
  • Spring Security in Action 第三章 SpringSecurity管理用户
  • Java面试——maven篇
  • 基于微信小程序的游戏账号交易小程序
  • Matlab绘制隐函数总结-二维和三维
  • 如何直观地理解傅立叶变换?频域和时域的理解
  • STC15读取内部ID示例程序