当前位置: 首页 > news >正文

React 中的 ErrorBoundary

在 React 中,如果不做任何控制,当组件出现异常时,React 渲染就会停止,页面出现白屏,这种体验很不好。例如当用户输入某些非法数据,而前端都没有进行校验,页面出现白屏。这种情况下,最好的方式是只针对出错的组件进行处理,将出错的组件进行替换,替换成错误提示组件,并显示错误信息,可以指导用户的下一步操作。React 通过 ErrorBoundary 组件进行错误处理,当组件出现错误时,组件停止当前渲染并通过 Fiber 向上查找,如果找到 ErrorBoundary,就显示 Fallback 组件,否则出现白屏。

看一个简单的例子,主要看 Error 组件,当抛出异常时,会显示白屏。

### App 组件
export default function App() {const AList = lazy(()=>import('./List.js'))const r = useRef(null)  const [show, setShow] = useState(false);return (<><TODO/><ErrorComponent/></>);
}
### Error 组件
import React from 'react';export function ErrorComponent(){// throw new Error('出错了!!');return <div style={{"text-align":"center", "font-size":"50px","color":"red"}}>错误</div>;}

异常被注释掉时,组件正常显示。
在这里插入图片描述
打开注释,页面崩溃。
在这里插入图片描述

getDerivedStateFromError

在 React 中,如果想捕获子组件的异常需要定义 getDerivedStateFromError,当子组件出现异常时 React 会调用这个方法。ErrorBoundary 需要是一个类组件,在组件中定义 getDerivedStateFromError 方法。以下代码实现了 ErrorBoundary 组件,重点看 getDerivedStateFromError 方法。

import React, { Component } from 'react';class ErrorBoundary extends Component {constructor(props) {super(props);this.state = { hasError: false };}static getDerivedStateFromError(error) {// Update state so the next render shows the fallback UI.return { hasError: true };}componentDidCatch(error, errorInfo) {// You can also log the error to an error reporting serviceconsole.log('Logging error:', error, errorInfo);}render() {if (this.state.hasError) {return <h1>组件出现异常</h1>;}return this.props.children; }
}export default ErrorBoundary;

将 ErrorComponent 设置为 Boundary 的子组件,组件被替换。

    <ErrorBoundary><ErrorComponent/></ErrorBoundary>

在这里插入图片描述

React 如何实现

跟踪一下 React 代码,看 React 如何实现 getDerivedStateFromError,在组件发生异常时通过 try/catch 捕获并进入 handleError 方法
在这里插入图片描述
进入 handleError 并调用 throwException 方法
在这里插入图片描述
在 throwException 中判断是否存在 getDerivedStateFromError 方法,如果存在继续处理,进入createClassErrorUpdate
在这里插入图片描述
创建 update 并返回,update.payload 方法会调用 getDerivedStateFromError
在这里插入图片描述
将 update 加入 WIP 中的 updateQueue
在这里插入图片描述

从throwException 返回,进入 completeUnitOfWork,并返回 returnFiber (ErrorBoundary)。
在这里插入图片描述
最后最近进入finishClassComponent 渲染组件
在这里插入图片描述

总结

React 框架中通过 getDerivedStateFromError 方法进行异常处理,项目开发可以自定义一个类组件并实现该方法进行组件异常处理。

相关文章:

  • 数据分析:置换检验Permutation Test
  • 【JavaEE】Spring Web MVC详解
  • 【ajax核心05】宏任务与微任务
  • 【计算机网络】已解决:“‘ping‘ 不是内部或外部命令,也不是可运行的程序或批处理文件”报错
  • 2-14 基于matlab的GA优化算法优化车间调度问题
  • PMBOK® 第六版 管理项目知识
  • 如何使用Dockerfile创建容器映像
  • 解决WebStorm中不显示npm任务面板
  • JetBrains IDEA 新旧UI切换
  • Linux文本三剑客sed
  • Spring响应式编程之Reactor核心组件
  • 网络聚合通信测试--自动化测试脚本
  • 6月20日(周四)A股行情总结:A股险守3000点,恒生科技指数跌1.6%
  • EVALUATE与XLWT与XLRD一种使用方式
  • 【机器学习300问】125、什么是双向循环神经网络(BRNN)?什么是深度循环神经网络(DRNN)?
  • 网络传输文件的问题
  • #Java异常处理
  • 【剑指offer】让抽象问题具体化
  • 【跃迁之路】【585天】程序员高效学习方法论探索系列(实验阶段342-2018.09.13)...
  • golang 发送GET和POST示例
  • input实现文字超出省略号功能
  • JavaWeb(学习笔记二)
  • Linux快速复制或删除大量小文件
  • Odoo domain写法及运用
  • select2 取值 遍历 设置默认值
  • SpringBoot几种定时任务的实现方式
  • Travix是如何部署应用程序到Kubernetes上的
  • Vim 折腾记
  • vue从入门到进阶:计算属性computed与侦听器watch(三)
  • windows下使用nginx调试简介
  • 搭建gitbook 和 访问权限认证
  • 动手做个聊天室,前端工程师百无聊赖的人生
  • 分类模型——Logistics Regression
  • 微服务入门【系列视频课程】
  • 硬币翻转问题,区间操作
  • 与 ConTeXt MkIV 官方文档的接驳
  • 如何通过报表单元格右键控制报表跳转到不同链接地址 ...
  • #100天计划# 2013年9月29日
  • #stm32驱动外设模块总结w5500模块
  • (145)光线追踪距离场柔和阴影
  • (Pytorch框架)神经网络输出维度调试,做出我们自己的网络来!!(详细教程~)
  • (八)光盘的挂载与解挂、挂载CentOS镜像、rpm安装软件详细学习笔记
  • (二)PySpark3:SparkSQL编程
  • (附源码)ssm旅游企业财务管理系统 毕业设计 102100
  • (附源码)计算机毕业设计ssm电影分享网站
  • (个人笔记质量不佳)SQL 左连接、右连接、内连接的区别
  • (三维重建学习)已有位姿放入colmap和3D Gaussian Splatting训练
  • (十)Flink Table API 和 SQL 基本概念
  • (一)pytest自动化测试框架之生成测试报告(mac系统)
  • (转)Linux下编译安装log4cxx
  • ******IT公司面试题汇总+优秀技术博客汇总
  • *算法训练(leetcode)第四十天 | 647. 回文子串、516. 最长回文子序列
  • .NET BackgroundWorker
  • .net core webapi Startup 注入ConfigurePrimaryHttpMessageHandler
  • .net core控制台应用程序初识