getInitialProps
**注意**:
getInitialProps
是一个旧版 API。我们建议改用getStaticProps
或getServerSideProps
。
getInitialProps
是一个 async
函数,可以添加到页面的默认导出 React 组件中。它将在服务器端运行,并在页面转换期间在客户端再次运行。该函数的结果将作为 props
转发到 React 组件。
pages/index.tsx
import { NextPageContext } from 'next'
Page.getInitialProps = async (ctx: NextPageContext) => {
const res = await fetch('https://api.github.com/repos/vercel/next.js')
const json = await res.json()
return { stars: json.stargazers_count }
}
export default function Page({ stars }: { stars: number }) {
return stars
}
注意:
- 服务器渲染时,
getInitialProps
返回的数据会被序列化。确保getInitialProps
返回的对象是普通的Object
,而不是使用Date
、Map
或Set
。- 对于初始页面加载,
getInitialProps
仅在服务器上运行。使用next/link
组件或next/router
导航到不同的路由时,getInitialProps
也会在客户端运行。- 如果在自定义
_app.js
中使用getInitialProps
,并且正在导航到的页面正在使用getServerSideProps
,则getInitialProps
也会在服务器上运行。
上下文对象
getInitialProps
接收一个名为 context
的单个参数,该参数是一个包含以下属性的对象
名称 | 描述 |
---|---|
pathname | 当前路由,/pages 中页面的路径 |
query | URL 的查询字符串,解析为对象 |
asPath | 浏览器中显示的实际路径(包括查询)的 String |
req | HTTP 请求对象(仅限服务器) |
res | HTTP 响应对象(仅限服务器) |
err | 如果在渲染过程中遇到任何错误,则为错误对象 |
注意事项
这有帮助吗?