react 错误边界
如果一个 class 组件中定义了 static getDerivedStateFromError()
或 componentDidCatch()
这两个生命周期方法中的任意一个(或两个)时,那么它就变成一个错误边界。当抛出错误后,请使用 static getDerivedStateFromError()
渲染备用 UI ,使用 componentDidCatch()
打印错误信息。
import React from 'react'; import ReactDOM from 'react-dom'; class ErrorBoundary extends React.Component { constructor(props) { super(props); this.state = { hasError: false }; } componentDidCatch(err, info) { this.setState({ hasError: true }); } render() { if (this.state.hasError) { return <h1>Something Went Wrong</h1> } return this.props.children; } } class Page extends React.Component { render() { return ( <ErrorBoundary> <Clock /> </ErrorBoundary> ) } } class Clock extends React.Component { render() { return ( <div> {null.toString()} <div>hello</div> </div> ) } } ReactDOM.render(<Page />, document.querySelector('#root'));
- 大多数情况下, 你只需要声明一次错误边界组件, 并在整个应用中使用它。
- 注意错误边界仅可以捕获其子组件的错误,它无法捕获其自身的错误。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论