React学习第三天——生命周期

生命周期

注意:生命周期钩子函数通常指的是类组件独有的东西

常用的生命周期钩子函数

官网在介绍生命周期也分为了常用不常用 两大块进行介绍

常用:

  • constructor 初始化操作
    同一个组件对象只会创建一次
    不能在挂载页面前,调用setState,为了避免问题,构造函数中严禁使用setState

    class App extends React.Component{
    constructor(){
    super()
    //在constructor中进行初始化操作
    this.state = {
    val: ''
    }
    }
    }
    export default App

  • render
    render是整个类组件中必须书写的生命周期方法
    返回一个虚拟dom,会被挂载到虚拟dom树,最终渲染到真是dom
    render可能不止渲染一次,只要视图更新,render就会重新运行
    严禁使用setState,可能会导致无限递归

    import React from "react"
    class App extends React.Component{
    constructor(){
    super()
    // 主要做初始化操作,例如该组件的状态
    this.state = {
    val: ''
    }
    console.log('constructor');

    复制代码
    }
    handleClick = () => {
      this.setState({
        val: this.state.val + 1
      })
    }
    render(){
      /**
       * 会产生递归
       * this.setState({
       *    val: this.state.val + 1
       * })
       */
      console.log('render'); //执行多次
      return (
        <div>
          {this.state.val}
          <button onClick={this.handleClick}>+1</button>
        </div>
      )
    }

    }
    export default App

  • componentDidMount
    类似于vue中的mounted
    只执行一次
    可以使用setState
    通常情况,将网络请求,启动计时器等一开始需要的操作,书写咋该函数中

    componentDidMount(){
    console.log('componentDidMount');
    //接下来,发送Ajax亲求,或者绑定计时器等操作
    }

  • componentWillUnmount
    通常在该函数中销毁组件依赖的资源,比如计时器

    componentWillUnmount(){
    //组件销毁时调用该生命周期钩子

    复制代码
    }
相关推荐
mCell1 天前
前端路由详解:Hash vs History
前端·javascript·vue-router
海上彼尚1 天前
无需绑卡的海外地图
前端·javascript·vue.js·node.js
1024肥宅1 天前
手写 call、apply、bind 的实现
前端·javascript·ecmascript 6
科杰智能制造1 天前
纯前端html、js实现人脸检测和表情检测,可直接在浏览器使用
前端·javascript·html
c***21291 天前
Springboot3学习(5、Druid使用及配置)
android·学习
每天吃饭的羊1 天前
组件库的有些点击事件是name-click这是如何分装de
前端·javascript·vue.js
x***01061 天前
SpringSecurity+jwt实现权限认证功能
android·前端·后端
1024肥宅1 天前
防抖(Debounce)
前端·javascript·ecmascript 6
1024肥宅1 天前
节流(Throttle)
前端·javascript·ecmascript 6
by__csdn1 天前
Vue2纯前端图形验证码实现详解+源码
前端·javascript·typescript·vue·状态模式·css3·canva可画