什么是边界错误
Error boundary:错误边界。它是react16.0版本发布的时候,携带的一个新的特性。在它的中文官方文档中有这样一段描述:
过去,组件内的 JavaScript 错误会导致 React 的内部状态被破坏,并且在下一次渲染时 产生 可能无法追踪的 错误。这些错误基本上是由较早的其他代码(非 React 组件代码)错误引起的,但 React 并没有提供一种在组件中优雅处理这些错误的方式,也无法从错误中恢复。
根据官方文档的描述,它诞生的目的就是为了在部分UI出现JavaScript错误的时候。不应该导致整个应用的崩溃。
特性说明
错误边界本质上时react的一种组件。官方文档是这样定义:
错误边界是一种 React 组件,这种组件 可以捕获并打印发生在其子组件树任何位置的 JavaScript 错误,并且,它会渲染出备用 UI ,而不是渲染那些崩溃了的子组件树。错误边界在渲染期间、生命周期方法和整个组件树的构造函数中捕获错误。
然而错误边界并不能监控所有错误
以下错误是错误边界无法捕获的
- 事件处理(了解更多)
- 异步代码(例如 setTimeout 或 requestAnimationFrame 回调函数)
- 服务端渲染
- 它自身抛出来的错误(并非它的子组件)
如果在class组件中定义了 static getDerivedStateFromError() 或 componentDidCatch() 这两个生命周期方法中的任意一个(或两个)时,那么它就变成一个错误边界。当抛出错误后,可以利用 static getDerivedStateFromError() 渲染备用UI 同时可以利用 componentDidCatch()来打印错误信息。
错误组件:
class ErrorBoundary extends React.Component {
constructor(props) {
super(props);
this.state = { hasError: false };
}
static getDerivedStateFromError(error) {
// Update state so the next render will show the fallback UI.
return { hasError: true };
}
componentDidCatch(error, info) {
// You can also log the error to an error reporting service
logErrorToMyService(error, info);
}
render() {
if (this.state.hasError) {
// You can render any custom fallback UI
return \<h1\>Something went wrong.\</h1\>;
}
return this.props.children;
}
}
Error boundary是一个react组件。所以我们可以在常规组件中引入错误组件:
<ErrorBoundary>
<MyWidget />
</ErrorBoundary>
错误边界只能捕获子组件发生的错误。如果错误无法被错误边界捕获,错误会冒泡至最近的上层组件。