React useEffect组件渲染执行操作 组件生命周期 监视器 副作用

介绍

useEffect 是 React Hook 中非常重要的一个,它用于处理副作用(side effects)。副作用包括数据获取、订阅、手动修改 DOM 等等。在 React 函数组件中,useEffect 让你能够在组件渲染后执行某些操作,类似于类组件中的 componentDidMount, componentDidUpdate, 和 componentWillUnmount。

例子

javascript 复制代码
import {useEffect} from "react";

function App() {

    useEffect(()=>{
    //组件渲染完成的回调函数

        const list=getList() //模拟请求获取数据
        console.log(list)

    },[])//[] 依赖项

    function getList(){ //模拟获取数据
        return [1,2,3,4,5]
    }

    return <div  className="box">

    </div>

}

空依赖数组 ([])

只在初始渲染时执行一次

javascript 复制代码
useEffect(() => {
    // 这个副作用只会在组件挂载时执行一次
}, []);

有依赖的数组 [dep1, dep2, ...]

  • 组件挂载时执行一次
  • 当依赖项之一发生变化时,副作用函数会重新执行。
  • 适用场景: 你希望在某些数据或状态变化时执行副作用,比如更新 UI 或发送网络请求等。
javascript 复制代码
useEffect(() => {
    // 只有当依赖项改变时才会执行副作用函数
}, [dep1, dep2]);

没有依赖项(useEffect() 没有第二个参数)

组件初始渲染+组件更新时执行

适用场景: 如果副作用需要在每次渲染后执行,例如实时跟踪某些状态变化,或者清理某些动画、事件监听等。

javascript 复制代码
useEffect(() => {
    // 副作用每次渲染时都会执行
});

清除副作用

清除副作用通常是指在组件卸载时或副作用重新执行之前进行清理操作。这是为了避免内存泄漏、重复执行或不必要的资源占用。

javascript 复制代码
useEffect(() => {
    // 执行副作用


    // 返回清理函数
    return () => {
        // 清理副作用

    };
}, [/* 依赖项 */]);
相关推荐
kingwebo'sZone5 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09015 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农5 小时前
Vue 2.3
前端·javascript·vue.js
夜郎king6 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落
夏幻灵7 小时前
HTML5里最常用的十大标签
前端·html·html5
Mr Xu_7 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝7 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions7 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发7 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_7 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html