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 () => {
        // 清理副作用

    };
}, [/* 依赖项 */]);
相关推荐
阿珊和她的猫1 天前
React Hooks:革新组件开发的优势与实践
前端·react.js·状态模式
全栈技术负责人1 天前
AI时代前端工程师的转型之路
前端·人工智能
花归去1 天前
echarts 柱状图曲线图
开发语言·前端·javascript
喝拿铁写前端1 天前
当 AI 会写代码之后,我们应该怎么“管”它?
前端·人工智能
老前端的功夫1 天前
TypeScript 类型魔术:模板字面量类型的深层解密与工程实践
前端·javascript·ubuntu·架构·typescript·前端框架
Nan_Shu_6141 天前
学习: Threejs (2)
前端·javascript·学习
G_G#1 天前
纯前端js插件实现同一浏览器控制只允许打开一个标签,处理session变更问题
前端·javascript·浏览器标签页通信·只允许一个标签页
@大迁世界1 天前
TypeScript 的本质并非类型,而是信任
开发语言·前端·javascript·typescript·ecmascript
GIS之路1 天前
GDAL 实现矢量裁剪
前端·python·信息可视化
是一个Bug1 天前
后端开发者视角的前端开发面试题清单(50道)
前端