react生命周期图谱汇总

2019-12-10  本文已影响0人  xinyiyake

react v16中组件生命周期图谱汇总,包含了组件 挂载——更新——卸载 这三个生命阶段:

react组件生命周期图谱

1. 挂载阶段

当组件实例被创建并插入 DOM 中时,其生命周期调用顺序如下:

2. 更新阶段

当组件的 props 或 state 发生变化时会触发更新。组件更新的生命周期调用顺序如下:

3. 卸载阶段

当组件从 DOM 中移除时会调用如下方法:

4. 错误处理

当渲染过程,生命周期,或子组件的构造函数中抛出错误时,会调用如下方法:

class ErrorBoundary extends React.Component {
  constructor(props) {
    super(props);
    this.state = { hasError: false };
  }

  static getDerivedStateFromError(error) {
    // 更新 state 使下一次渲染可以显示降级 UI
    return { hasError: true };
  }

  componentDidCatch(error, info) {
    // "组件堆栈" 例子:
    //   in ComponentThatThrows (created by App)
    //   in ErrorBoundary (created by App)
    //   in div (created by App)
    //   in App
    logComponentStackToMyService(info.componentStack);
  }

  render() {
    if (this.state.hasError) {
      // 你可以渲染任何自定义的降级 UI
      return <h1>Something went wrong.</h1>;
    }  

    return this.props.children; 
  }
}
上一篇下一篇

猜你喜欢

热点阅读