一、什么是错误边界 错误边界是一种 React 组件,这种组件可以捕获发生在其子组件树任何位置的 JavaScript 错误,并打印这些错误,同时展示降级 UI
,而并不会渲染那些发生崩溃的子组件树。错误边界在渲染期间、生命周期方法和整个组件树的构造函数中捕获错误。
注意:错误边界无法捕获以下场景中产生的错误【React|React 错误边界之 react-error-boundary】如果一个 class 组件中定义了
- 事件处理
- 异步代码(例如 setTimeout 或 requestAnimationFrame 回调函数)
- 服务端渲染
- 它自身抛出来的错误(并非它的子组件)
static getDerivedStateFromError()
或 componentDidCatch()
这两个生命周期方法中的任意一个(或两个)时,那么它就变成一个错误边界。当抛出错误后,请使用 static getDerivedStateFromError()
渲染备用 UI ,使用 componentDidCatch()
打印错误信息。class ErrorBoundary extends React.Component {
constructor(props) {
super(props);
this.state = { hasError: false };
}static getDerivedStateFromError(error) {
// 更新 state 使下一次渲染能够显示降级后的 UI
return { hasError: true };
}componentDidCatch(error, errorInfo) {
// 你同样可以将错误日志上报给服务器
logErrorToMyService(error, errorInfo);
}render() {
if (this.state.hasError) {
// 你可以自定义降级后的 UI 并渲染
return Something went wrong.;
}return this.props.children;
}
}
然后你可以将它作为一个常规组件去使用:
错误边界的工作方式类似于 JavaScript 的 catch {},不同的地方在于错误边界只针对 React 组件。只有 class 组件才可以成为错误边界组件。大多数情况下, 你只需要声明一次错误边界组件, 并在整个应用中使用它。
注意错误边界仅可以捕获其子组件的错误,它无法捕获其自身的错误。如果一个错误边界无法渲染错误信息,则错误会冒泡至最近的上层错误边界,这也类似于 JavaScript 中 catch {} 的工作机制。
二、react-error-boundary https://github.com/bvaughn/react-error-boundary
https://www.npmjs.com/package/react-error-boundary
以上 地址是大佬封装好的error-boundary 轮子,可以直接拿来用,具体如何使用,查看相关文档即可
推荐阅读
- react|封装一个处理 react 异常的最简 ErrorBoundary 组件
- react|React Native Sectionlist item移除动画
- php|HTML及CSS学习笔记
- 前端|对请求,响应和前后端生命周期的理解。
- 微信小程序|基于uni-app实现微信小程序一键登录和退出登录功能
- React报错之Cannot assign to 'current'
- 前端|聊一聊前端程序员的现状与挑战
- 一起来学华为云数据库,RDS实践
- React报错之The tag is unrecognized in this browser