自定义错误页面
404 页面
404 页面可能会被频繁访问。每次访问都进行服务端渲染 (SSR) 会增加 Next.js 服务器的负载,可能导致成本上升和体验变慢。
为避免上述问题,Next.js 默认提供了一个静态 404 页面,无需添加任何额外文件。
自定义 404 页面
要创建自定义 404 页面,可以创建 pages/404.js
文件。该文件会在构建时静态生成。
须知:如果需要获取构建时的数据,可以在该页面中使用
getStaticProps
。
500 页面
每次访问都进行服务端渲染 (SSR) 错误页面会增加错误响应的复杂性。为了帮助用户快速获取错误响应,Next.js 默认提供了一个静态 500 页面,无需添加任何额外文件。
自定义 500 页面
要自定义 500 页面,可以创建 pages/500.js
文件。该文件会在构建时静态生成。
须知:如果需要获取构建时的数据,可以在该页面中使用
getStaticProps
。
更高级的错误页面自定义
500 错误由 Error
组件在客户端和服务端同时处理。如需覆盖默认行为,可创建 pages/_error.js
文件并添加以下代码:
pages/_error.js
仅在生产环境中使用。开发环境下会显示包含错误调用栈的信息。
复用内置错误页面
如需渲染内置错误页面,可以通过导入 Error
组件实现:
Error
组件还接受 title
属性,用于在 statusCode
之外传递文本消息。
如果已有自定义 Error
组件,请确保导入的是自定义组件而非默认组件。next/error
导出的是 Next.js 使用的默认组件。
注意事项
Error
组件目前不支持 Next.js 的数据获取方法,例如getStaticProps
或getServerSideProps
。- 与
_app
类似,_error
是保留路径名。_error
用于定义错误页面的自定义布局和行为。直接通过路由访问或自定义服务器渲染时,/_error
会显示 404 页面。