react hooks的useEffect:

React 的 useEffect Hook 用于在函数组件中执行副作用操作(例如数据获取、订阅事件等),它类似于类组件中的生命周期方法 componentDidMountcomponentDidUpdatecomponentWillUnmount 的组合。

useEffect 接收一个回调函数和一个可选的依赖数组。

复制代码
import { useEffect } from 'react';

useEffect(() => {
  // 在这里执行副作用操作

  // 返回一个清除函数(可选)
  return () => {
    // 在组件销毁之前执行清除操作
  };
}, [依赖数组]);

回调函数作为参数传递给 useEffect,它将在组件渲染后执行,每次组件更新时也会重新执行。

依赖数组是一个可选的参数,在数组中指定的依赖发生变化时, useEffect 将重新执行回调函数。如果省略了依赖数组,则每次组件更新时都会重新执行回调函数。

在回调函数中,我们可以进行各种副作用操作,比如订阅事件、发送网络请求、操作 DOM 等。

返回的清除函数(可选)将在组件销毁之前执行,用于清理副作用操作,比如取消订阅、清除定时器等。

以下是几个使用 useEffect 的示例:

  1. 基本用法:在组件渲染后执行副作用操作。

    import { useEffect } from 'react';

    function MyComponent() {
    useEffect(() => {
    console.log('Component rendered');

    复制代码
     return () => {
       console.log('Component cleanup');
     };

    }, []);

    return null;
    }

  2. 使用依赖项:在依赖项发生变化时执行副作用操作。

    import { useEffect, useState } from 'react';

    function MyComponent() {
    const [count, setCount] = useState(0);

    useEffect(() => {
    console.log(Count changed: ${count});

    复制代码
     return () => {
       console.log('Component cleanup');
     };

    }, [count]);

    return (


    <button onClick={() => setCount(count + 1)}>Increment</button>

    );
    }

  3. 清理副作用操作:在组件销毁前执行清除操作。

    import { useEffect } from 'react';

    function MyComponent() {
    useEffect(() => {
    const subscription = subscribeToEvents();

    复制代码
     return () => {
       unsubscribeFromEvents(subscription);
     };

    }, []);

    return null;
    }

在这个例子中,我们订阅了一些事件,返回的清除函数会在组件销毁前取消订阅。

通过使用 useEffect Hook,我们可以将副作用操作集成到函数组件中,并根据需要进行清理操作,使组件更加灵活和可维护。

相关推荐
Cache技术分享9 小时前
254. Java 集合 - 使用 Lambda 表达式操作 Map 的值
前端·后端
CryptoPP9 小时前
使用 KLineChart 这个轻量级的前端图表库
服务器·开发语言·前端·windows·后端·golang
p***43489 小时前
前端路由管理
前端
是一碗螺丝粉10 小时前
React Native 运行时深度解析
前端·react native·react.js
Jing_Rainbow10 小时前
【前端三剑客-9 /Lesson17(2025-11-01)】CSS 盒子模型详解:从标准盒模型到怪异(IE)盒模型📦
前端·css·前端框架
爱泡脚的鸡腿10 小时前
uni-app D6 实战(小兔鲜)
前端·vue.js
青年优品前端团队10 小时前
🚀 不仅是工具库,更是国内前端开发的“瑞士军刀” —— @qnvip/core
前端
骑自行车的码农10 小时前
🍂 React DOM树的构建原理和算法
javascript·算法·react.js
北极糊的狐10 小时前
Vue3 中父子组件传参是组件通信的核心场景,需遵循「父传子靠 Props,子传父靠自定义事件」的原则,以下是资料总结
前端·javascript·vue.js