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(){
    //组件销毁时调用该生命周期钩子

    复制代码
    }
相关推荐
jeffwang16 分钟前
我做了个让 AI 看屏幕跑测试的工具,因为 Playwright 测不了我的 Flutter Web
前端
HSunR1 小时前
dify 搭建ai作业批改流
开发语言·前端·javascript
代码不加糖1 小时前
2026 跨境电商独立站实战:从 0 到 1 搭建高转化 SaaS 商城(附源码)
开发语言·前端·javascript
亲亲小宝宝鸭1 小时前
拖一拖控件,拖出个问卷(低代码平台)
前端·低代码
江南十四行1 小时前
ReAct Agent 基本理论与项目实战(一)
前端·react.js·前端框架
幸福巡礼2 小时前
【LangChain 1.2 实战(一)】 概述
笔记·学习·langchain
We་ct2 小时前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·leetcode·typescript·动态规划
小呆呆6662 小时前
Codex 穷鬼大救星
前端·人工智能·后端
知识分享小能手2 小时前
R语言入门学习教程,从入门到精通,R语言数据计算与分组统计(9)
开发语言·学习·r语言
lizhihai_993 小时前
股市学习心得—半导体12种核心材料
大数据·人工智能·学习