React中的componentWillUnmount 使用

如果你定义了 componentWillUnmount 方法,React 会在你的组件被移除屏幕(卸载)之前调用它。此方法常常用于取消数据获取或移除监听事件。

componentWillUnmount 内部的逻辑应该完全"对应"到 componentDidMount 内部的逻辑,例如,如果你在 componentDidMount 中设置了一个监听事件,那么 componentWillUnmount 中就应该清除掉这个监听事件。如果你的 componentWillUnmount 的清理逻辑中读取了一些 props 或者 state,那么你通常还需要实现一个 componentDidUpdate 来清理使用了旧 props 和 state 的资源(例如监听事件)。

复制代码
import React from 'react';
import './App.css';


class Bpp extends React.Component {

  componentWillUnmount() {
    console.log('组件卸载');
  }
  render() {
    return (
      <div>
        <h1>我是Bpp组件</h1>
      </div>
    );
  }
}

class App extends React.Component {

  constructor(props) {
    super(props);
    this.state = {
     bpp_show:true

    };
  }

  
  componentDidMount() {
    console.log('组件挂载完成');
  }
  //定义事件
  click = () => {
    this.setState({
      bpp_show:false
    })  }
  // 渲染组件UI,返回React元素
  render() {
    const { bpp_show } = this.state;
    return (
      <div>
        {bpp_show && <Bpp></Bpp>}
        <button onClick={this.click}>
      隐藏bpp
        </button>
      </div>
  
  )

  }
}

export default App;
相关推荐
1***s6326 小时前
Vue图像处理开发
javascript·vue.js·ecmascript
一 乐7 小时前
应急知识学习|基于springboot+vue的应急知识学习系统(源码+数据库+文档)
数据库·vue.js·spring boot
槁***耿7 小时前
JavaScript在Node.js中的事件发射器
开发语言·javascript·node.js
一叶茶7 小时前
移动端平板打开的三种模式。
前端·javascript
前端大卫7 小时前
一文搞懂 Webpack 分包:async、initial 与 all 的区别【附源码】
前端
U***49837 小时前
JavaScript在Node.js中的Strapi
开发语言·javascript·node.js
Want5957 小时前
HTML音乐圣诞树
前端·html
老前端的功夫8 小时前
前端浏览器缓存深度解析:从网络请求到极致性能优化
前端·javascript·网络·缓存·性能优化
Running_slave8 小时前
你应该了解的TCP滑窗
前端·网络协议·tcp/ip
程序员小寒9 小时前
前端高频面试题之CSS篇(一)
前端·css·面试·css3