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
    }
  };
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值