错误边界(Error boundary)

  • 错误边界(Error boundary): 用来捕获后代组件错误,渲染出备用页面
  • 只能捕获后代组件生命周期产生的错误,不能捕获自己组件产生的错误和其他组件在合成事件、定时器中产生的错误

  • getDerivedStateFromError配合componentDidCatch

    案例

    子组件:

    import React, { Component } from 'react'
    
    export default class Child extends Component {
        state = {
            // user: [
            //     { id: '001', name: 'sun', age: 18 },
            //     { id: '002', name: 'feng', age: 19 },
            //     { id: '003', name: 'yuan', age: 20 },
            // ],
            user: 'abc',
        }
        render() {
            return (
                <div>
                    {this.state.user.map((item)=>{
                        return <li key={item.id}>{item.name}---{item.age}</li>
                    })}
                </div>
            )
        }
    }
    
    

    父组件:

    import React, { Component } from 'react'
    import Child from './child'
    
    export default class Parent extends Component {
      state = {
        // 用于标识子组件是否产生错误
        hasError:''
      }
    
      // 当parent的子组件出现报错时候,会触发getDerivedStateFromError,并携带错误信息
      static getDerivedStateFromError(error) {
        console.log('getDerivedStateFromError', error);
        return {
          hasError:error
        }
      }
      componentDidCatch(){
        console.log('统计错误次数,反馈给服务器。');
      }
    
      render() {
        return (
          <div>
            <h3>parent</h3>
            {this.state.hasError?<h2>子组件出错了~👌</h2>:<Child></Child>}
          </div>
        )
      }
    }
    
    

    运行结果:
    在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值