iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >React之错误边界ErrorBoundaries示例详解
  • 443
分享到

React之错误边界ErrorBoundaries示例详解

React错误边界ReactErrorBoundaries 2022-11-13 18:11:30 443人浏览 八月长安
摘要

目录引言注意实现错误边界应该放置在哪?未捕获错误(Uncaught Errors)该如何处理?注意:自 React 15 的命名更改引言 过去,组件内的代码异常会导致 React 的

引言

过去,组件内的代码异常会导致 React 的内部状态被破坏,产生可能无法追踪的错误。但 React 并没有提供一种优雅处理这些错误的方式,也无法从错误中恢复。

默认情况下,若一个组件在渲染期间(render)发生错误,会导致整个组件树全部被卸载,这当然不是我们期望的结果。

部分组件的错误不应该导致整个应用崩溃。为了解决这个问题,React 16 引入了一个新的概念 —— 错误边界

错误边界是一种 React 组件,这种组件可以捕获发生在其子组件树任何位置的异常,并打印这些错误,同时展示降级 UI,而并不会渲染那些发生崩溃的子组件树。

注意

  • 错误边界目前只在 Class Component 中实现了,没有在 hooks 中实现(因为Error Boundaries的实现借助了this.setState可以传递callback的特性,useState无法传入回调,所以无法完全对标);
  • 错误边界 无法捕获 以下四种场景中产生的错误:
    • 事件处理函数(因为 Error Boundaries 实现的本质是触发更新,但是事件处理函数不在render或者commit阶段,所以无法进行捕获,如果你需要在事件处理器内部捕获错误,可以使用原生的 try / catch 语句 了解更多)
    • 异步代码(例如 setTimeout 或 requestAnimationFrame 回调函数)
    • 服务端渲染(因为触发更新只能在客户端进行,不能在serve端进行)
    • 它自身抛出来的错误(因为错误抛出要向父节点冒泡寻找 Error Boundaries 处理,无法处理自身产生的错误)

实现

React中提供了两个与错误处理相关的api

  • getderivedstatefromerror:静态方法,当错误发生后,提供一个机会渲染 Fallback UI
  • componentDidCatch:组件实例方法,当错误发生后,提供一个机会记录错误信息

如果一个 class 组件中定义了 getDerivedStateFromError() 或 componentDidCatch() 这两个生命周期方法中的任意一个(或两个)时,那么它就变成一个错误边界。当抛出错误后,请使用 getDerivedStateFromError() 渲染备用 UI ,使用 componentDidCatch() 打印错误信息。

class ErrorBoundary extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      hasError: false,
    };
  }
  getDerivedStateFromError(error) {
    // 更新 state 使下一次渲染能够显示降级后的 UI
    return { hasError: true };
  }
  componentDidCatch(error, errorInfo) {
    // 你同样可以将错误日志上报给服务器
    logErrorToService(error, errorInfo);
  }
  render() {
    if (this.state.hasError) {
      // 你可以自定义降级后的 UI 并渲染
      return <h1>wrong message</h1>;
    }
    return this.props.children;
  }
}
export default ErrorBoundary;

然后你可以将它作为一个常规组件去使用:

<ErrorBoundary>
  <A />
  <B />
  <C />
</ErrorBoundary>

错误边界的工作方式类似于原生的 catch {},不同的地方在于,错误边界只针对 React 组件。并且只有 class 组件才可以成为错误边界组件。大多数情况下, 你只需要声明一次错误边界组件, 并在整个应用中使用它。

错误边界应该放置在哪?

错误边界的粒度由你来决定,可以将其包装在最顶层的路由组件中,并为用户展示一个 “xxx” 的错误信息,就像服务端框架经常处理崩溃一样。也可以将单独的组件包装在错误边界,从而保护其它组件不会崩溃。(例如,Facebook Messenger 将侧边栏、信息面板、聊天记录以及信息输入框包装在单独的错误边界中。如果其中的某些 UI 组件崩溃,其余部分仍然能够交互。)

未捕获错误(Uncaught Errors)该如何处理?

自 React 16 起,任何未被错误边界捕获的错误将会导致整个 React 组件树被卸载。

在某些场景下,把一个错误的 UI 留在那,比完全移除它要更糟糕。比如在类似 Messenger 的产品中,把一个异常的 UI 展示给用户,可能会导致用户把错误信息发给别人。同样,对于支付类场景而言,与其显示错误的支付金额,不如直接让页面白屏。

(所以,错误边界的使用难点在于寻找合适的时机,知道在什么时候该用,什么时候不该用,这是一个充满哲学的问题)

注意:自 React 15 的命名更改

React 15 中有一个支持有限的错误边界方法 unstable_handleError。这个方法不再起作用,自 React 16 起你需要在代码中将其修改为 componentDidCatch

以上就是React之错误边界 Error Boundaries示例详解的详细内容,更多关于React 错误边界的资料请关注编程网其它相关文章!

--结束END--

本文标题: React之错误边界ErrorBoundaries示例详解

本文链接: https://www.lsjlt.com/news/170030.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • React之错误边界ErrorBoundaries示例详解
    目录引言注意实现错误边界应该放置在哪?未捕获错误(Uncaught Errors)该如何处理?注意:自 React 15 的命名更改引言 过去,组件内的代码异常会导致 React 的...
    99+
    2022-11-13
    React 错误边界 React Error Boundaries
  • React错误边界ErrorBoundaries详解
    目录错误边界(Error Boundaries)概述错误边界无法捕获以下场景中的错误渲染备用UI-static getDerivedStateFromError()打印错误信息-co...
    99+
    2022-12-03
    React错误边界 React Error Boundaries
  • React错误边界ErrorBoundaries
    首先 我们先构建出问题的场景 我们创建一个react项目 然后在src下创建 components 文件夹目录 在下面创建一个 error.jsx 组件 参开代码如下 import ...
    99+
    2023-01-29
    React错误边界Error Boundaries React错误边界
  • React 错误边界Error Boundary使用示例解析
    目录我们为什么需要错误边界如何使用错误边界组件使用错误边界需要注意什么我们为什么需要错误边界 在React组件中可能会由于某些JavaScript错误,导致一些无法追踪的错误,导致应...
    99+
    2024-04-02
  • React如何定义错误边界
    这篇文章将为大家详细讲解有关React如何定义错误边界,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。定义错误边界在Javascript里,我们都是使用 try/catch 来捕捉可能发...
    99+
    2023-06-26
  • React 错误边界组件的处理
    这是React16的内容,并不是最新的技术,但是用很少被讨论,直到通过文档发现其实也是很有用的一部分内容,还是总结一下~ React中的未捕获的 JS 错误会导致整个应用的崩溃,和整...
    99+
    2024-04-02
  • React中Portals与错误边界处理实现
    目录Portals 错误边界处理 如果没有使用错误边界会怎样? 注意点 Portals 可以说是 插槽,但 不同于 Vue 中的 slot,它指的是将一个 React 元素渲染到指...
    99+
    2024-04-02
  • 怎么在React中处理错误边界组件
    这期内容当中小编将会给大家带来有关怎么在React中处理错误边界组件,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。React中的未捕获的 JS 错误会导致整个应用的崩溃,和整个组件树的卸载。从 React...
    99+
    2023-06-14
  • React中Portals与错误边界处理实现方法
    这篇文章主要讲解了“React中Portals与错误边界处理实现方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“React中Portals与错误边界处理实现方法”吧!目录Portals错误...
    99+
    2023-06-20
  • React中Portals与错误边界处理怎么实现
    这篇“React中Portals与错误边界处理怎么实现”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React中Portal...
    99+
    2023-06-05
  • React 模式之纯组件使用示例详解
    目录什么是纯组件纯组件解决了什么问题怎么使用纯组件CC: shouldComponentUpdate() 和 React.PureComponentFC: React.memo()你...
    99+
    2024-04-02
  • React特征学习之Form格式示例详解
    目录Form 样式React hookForm 样式 首先来看一个简单Form, 式样如下 import * as React from 'react'; const LoginFo...
    99+
    2024-04-02
  • react-redux的connect示例详解
    connect简介:connect是react-redux两个api中其中之一,在使用react-redux时起到了为redux中常用的功能实现了和react连接的建立函数入口,以及...
    99+
    2023-01-31
    react-redux的connect react-redux
  • react使用useImperativeHandle示例详解
    目录1.前言2.useImperativeHandle初探3.获取元素的几种方式3.1 useRef:获取组件内部元素3.2 forwardRef:父组件获取子组件内部的一个元素3....
    99+
    2024-04-02
  • Promise抛出错误解决基础示例详解
    目录thencatchfinallyPromise.resolvePromise.reject then then 函数的会接收两个回调函数,一个是 onFulfilled 函数,一...
    99+
    2022-12-15
    Promise抛出错误解决 Promise 错误
  • Golang中的错误处理的示例详解
    目录1、panic2、包装错误3、错误类型判断4、错误值判断1、panic 当我们执行panic的时候会结束下面的流程: package main import "fmt" fu...
    99+
    2024-04-02
  • React 路由使用示例详解
    目录Router简单路由嵌套路由未匹配路由路由传参数索引路由活动链接搜索参数自定义行为useNavigate参考资料Router react-router-dom是一个处理页面跳转的...
    99+
    2024-04-02
  • React Redux管理库示例详解
    目录相同点不同点配置总共分为三部分Provider前言: 什么是redux?redux和vuex一样,都被统称为状态管理库,是核心数据存贮与分发、监听数据改变的核心所在。 可以简单说...
    99+
    2022-12-20
    React Redux React Redux管理库
  • mysql存储过程之错误处理实例详解
    本文实例讲述了mysql存储过程之错误处理。分享给大家供大家参考,具体如下: 当存储过程中发生错误时,重要的是适当处理它,例如:继续或退出当前代码块的执行,并发出有意义的错误消息。其中mysql提供了一种简...
    99+
    2024-04-02
  • 示例详解react中useState的用法
    useState useState 通过在函数组件里调用它来给组件添加一些内部 state。React 会在重复渲染时保留这个 state。useState 会返回一对值:当前状态...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作