React|React 错误边界之 react-error-boundary

一、什么是错误边界 错误边界是一种 React 组件,这种组件可以捕获发生在其子组件树任何位置的 JavaScript 错误,并打印这些错误,同时展示降级 UI,而并不会渲染那些发生崩溃的子组件树。错误边界在渲染期间、生命周期方法和整个组件树的构造函数中捕获错误。

注意:错误边界无法捕获以下场景中产生的错误
  1. 事件处理
  2. 异步代码(例如 setTimeout 或 requestAnimationFrame 回调函数)
  3. 服务端渲染
  4. 它自身抛出来的错误(并非它的子组件)
【React|React 错误边界之 react-error-boundary】如果一个 class 组件中定义了 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 轮子,可以直接拿来用,具体如何使用,查看相关文档即可

    推荐阅读