React -- useEffect

React - useEffect

概念理解

useEffect是一个React Hook函数,用于在React组件中创建不是由事件引起而是由渲染本身引起的操作(副作用), 比 如发送AJAX请求,更改DOM等等
在这里插入图片描述

:::warning
说明:上面的组件中没有发生任何的用户事件,组件渲染完毕之后就需要和服务器要数据,整个过程属于“只由渲染引起的操作”
:::

基础使用

需求:在组件渲染完毕之后,立刻从服务端获取平道列表数据并显示到页面中
在这里插入图片描述

  1. 参数1是一个函数,可以把它叫做副作用函数,在函数内部可以放置要执行的操作
  2. 参数2是一个数组(可选参),在数组里放置依赖项,不同依赖项会影响第一个参数函数的执行,当是一个空数组的时候,副作用函数只会在组件渲染完毕之后执行一次

useEffect依赖说明

useEffect副作用函数的执行时机存在多种情况,根据传入依赖项的不同,会有不同的执行表现

依赖项 副作用功函数的执行时机
没有依赖项 组件初始渲染 + 组件更新时执行
空数组依赖 只在初始渲染时执行一次
添加特定依赖项 组件初始渲染 + 依赖项变化时执行

清除副作用

概念:在useEffect中编写的由渲染本身引起的对接组件外部的操作,社区也经常把它叫做副作用操作,比如在useEffect中开启了一个定时器,我们想在组件卸载时把这个定时器再清理掉,这个过程就是清理副作用

import {
    useEffect, useState } from "react"

function Son () {
   
  // 1. 渲染时开启一个定时器
  useEffect(() => {
   
    const timer = setInterval(() => {
   
      console.log('定时器执行中...')
    }, 1000)

    return () => {
   
      // 清除副作用(组件卸载时)
      clearInterval(timer)
    }
  }, [])
  return <div>this is son</div>
}

function App () {
   
  // 通过条件渲染模拟组件卸载
  const [show, setShow] = useState(true)
  return (
    <div>
      {
   show && <Son />}
      <button onClick={
   () => setShow(false)}>卸载Son组件</button>
    </div>
  )
}

export default App

相关推荐

  1. react: useEffect

    2024-02-18 08:32:03       47 阅读
  2. react useEffect

    2024-02-18 08:32:03       35 阅读
  3. React useEffect使用

    2024-02-18 08:32:03       31 阅读
  4. react hook:useeffect

    2024-02-18 08:32:03       26 阅读
  5. 13 React useEffect 详解

    2024-02-18 08:32:03       17 阅读

最近更新

  1. xformers版本与其依赖pytorch版本的对应关系

    2024-02-18 08:32:03       0 阅读
  2. C++线程安全队列

    2024-02-18 08:32:03       0 阅读

热门阅读

  1. 开发实体类

    2024-02-18 08:32:03       28 阅读
  2. 【AI写文章】解释 Git 的基本概念和使用方式

    2024-02-18 08:32:03       30 阅读
  3. vllm 库调用大模型

    2024-02-18 08:32:03       32 阅读
  4. docker 安装jenkins

    2024-02-18 08:32:03       27 阅读
  5. 7.Cloud-GateWay

    2024-02-18 08:32:03       30 阅读
  6. vue面试题

    2024-02-18 08:32:03       28 阅读