首页 > 解决方案 > 反应组件消失时未调用componentWillUnmount方法

问题描述

我很难理解为什么在某些情况下componentWillUnmount即使卸载了我期望的组件也不调用方法。

更具体地说,这是一个例子。让我们考虑一个带有一个按钮和 2 个子组件的父组件:Child_Odd 和 Child_Even。如果按钮的点击次数是奇数,则 Child_Odd 为“显示”,否则 Child_Even 为“显示”。

我希望看到componentWillUnmount当组件“消失”时要调用的方法,但相反这不会发生。这里是重现该案例的 stackblitz(此 stackblitz 还包括componentWillUnmount实际调用该方法的类似案例)。

这是相关代码

export class ChildFlipped extends React.Component {
  render() {
    return (
      <div>
        {this.props.name} - No of clicks ({this.props.numberOfClicks})
      </div>
    );
  }
}

export class ParentFlips extends React.Component {
  constructor(props: any) {
    super(props);
    this.state = {
      clickCounter: 0,
    };
  }
  render() {
    return (
      <div>
        <button
          onClick={() => this.updateState()}
        >
          Click me
        </button>
        {this.state.clickCounter % 2 ? (
          <ChildFlipped
            name={"Even"}
            numberOfClicks={this.state.clickCounter}
          ></ChildFlipped>
        ) : (
          <ChildFlipped
            name={"Odd"}
            numberOfClicks={this.state.clickCounter}
          ></ChildFlipped>
        )}
      </div>
    );
  }
  updateState() {
    this.setState((prevState, _props) => ({
      clickCounter: prevState.clickCounter + 1,
    }));
  }
}

标签: reactjsreact-lifecycle

解决方案


它不会触发,因为组件仍然安装。关于和解,条件表达式

this.state.clickCounter % 2
? <ChildFlipped name={"Even"} numberOfClicks={this.state.clickCounter}/>
: <ChildFlipped name={"Odd"} numberOfClicks={this.state.clickCounter}/>

无法区分

<ChildFlipped name={this.state.clickCounter % 2? "Even" : "Odd"} 
              numberOfClicks={this.state.clickCounter}/>

因为这两个子句都指的是同一个ChildFlipped组件。如果添加键,则可以使它们可区分并触发卸载:

his.state.clickCounter % 2
? <ChildFlipped key='even' name={"Even"} numberOfClicks={this.state.clickCounter}/>
: <ChildFlipped key='odd' name={"Odd"} numberOfClicks={this.state.clickCounter}/>

为了试验生命周期方法,我构建了一个React 生命周期可视化工具(StackBlitz),它可能对你有用。


推荐阅读