React.js中的错误边界

错误边界机制有助于在生产时向用户显示有意义的错误消息,而不是显示任何编程语言错误。

创建一个反应类组件

import React, {Component} from 'react';
class ErrorBoundary extends Component{
   state={
      isErrorOccured:false,
      errorMessage:''
   }
   componentDidCatch=(error,info)=>{
      this.setState({isErrorOccured:true,errorMessage:error});
   }
   render(){
      if(this.state.isErrorOccured){
         return <p>Something went wrong</p>
      }else{
         return <div>{this.props.children}</div>
      }
   }
}
export default ErrorBoundary;

我们有一个带有两个变量isErrorOccured和errorMessage的状态对象,如果发生任何错误,它们将更新为true。

我们已经使用了React生命周期方法componentDidCatch,它接收到两个参数error和与之相关的信息。

在ErrorBoundary类的render方法中,我们正在检查是否设置了任何错误,我们正在显示一个简单的错误,指出“发生了错误”

如果没有错误设置,我们只是返回道具孩子

如何使用错误边界

<ErrorBoundary>
   <User/>
</ErrorBoundary>

我们将子组件包装在上面这样的错误边界内可能发生错误的地方。

请注意,这种错误边界方法仅适用于构建的生产模式。在开发模式下,它仅在浏览器上显示实际错误,而不是这些自定义错误。

在生产中使用错误边界有助于在屏幕上显示用户有意义的错误消息,而不是显示一些技术代码错误。