React Js ErrorBoundary 仅适用于主要布局组件,不适用于嵌套组件

问题描述

我在代码中使用了错误边界,当我在渲染主要布局组件的文件中使用它时,它可以工作,例如:

<ErrorBoundary>
<header></header>
</ErrorBoundary>
<ErrorBoundary>
<main/> //this component has an error
</ErrorBoundary>
<ErrorBoundary>
<footer></footer>
</ErrorBoundary>

上述代码有效,并且显示main 组件中的错误的回退 UI。但是当我在主组件文件中使用 errorboundary 组件时,它不起作用, 例如,错误边界不起作用:

class main extends React.Component {
//code
<ErrorBoundary>
{object}
</ErrorBoundary>
//more code

这不起作用,整个应用程序崩溃,只显示一个空白页面。为什么会发生这种情况以及如何处理?谢谢。

解决方法

我想通了。 Errorboundary 捕获组件中的错误。所以它没有更早地工作,但是当我在 ErrorBoundary 之间渲染一个有问题的组件时,它工作了。

<ErrorBoundary>
<FaultyComponent/>
</ErrorBoundary>

成功了。