当前位置: 首页 > news >正文

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

介绍

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

例子


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>}

空依赖数组 ([])

只在初始渲染时执行一次

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

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

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

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

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

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

清除副作用

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

useEffect(() => {// 执行副作用// 返回清理函数return () => {// 清理副作用};
}, [/* 依赖项 */]);
http://www.dtcms.com/a/490647.html

相关文章:

  • 在哪些场景下适合使用 v-model 机制?
  • 长沙申请域名网站备案查域名服务商
  • 游标卡尺 东莞网站建设大连建设工程信息网去哪里找
  • 华为USG防火墙之开局上网配置
  • 【第五章:计算机视觉-计算机视觉在医学领域中应用】1.生物细胞检测实战-(3)基于YOLO的细胞检测实战:数据读取、模型搭建、训练与测试
  • 【MFC实用技巧】对话框“边框”属性四大选项:None、Thin、Resizing、对话框外框,到底怎么选?
  • 网站备案 备注关联性天津网站建设内容
  • 所有网站收录入口济南市住监局官网
  • frida android quickstart
  • 作为测试工程师,我们该如何应用 AI?
  • 【Flutter】Flutter项目整体架构
  • 电子电气架构 --- 未来汽车软件架构
  • 怎么优化网站关键词辽宁省住房建设厅网站科技中心
  • 电力自动化新突破:Modbus如何变身Profinet?智能仪表连接的终极解决方案
  • cGVHD患者的血常规指标 生化指标 动态监测
  • 重庆网站建设师网站顶部布局
  • 【算法与数据结构】二叉树后序遍历非递归算法:保姆级教程(附具体实例+可运行代码)
  • AI-调查研究-105-具身智能 机器人学习数据采集:从示范视频到状态-动作对的流程解析
  • 基于 PyQt5 的多算法视频关键帧提取工具
  • 企业手机网站建设有wordpress download 插件
  • 【EE初阶 - 网络原理】应用层协议(上)
  • 2025国际集成电路展览会暨研讨会有那些新技术与亮点值得关注?
  • 【图片处理】✈️HTML转图片字体异常处理
  • Visual Studio 命令和属性的常用宏定义(macros for MSBuild commands and properties)
  • Android 中 gravity 与 layout_gravity 的深度解析:从概念到实践
  • 免费的招标网站有哪些wordpress编辑器上传图片
  • Spring初始
  • VB.Net循序渐进(第二版)
  • AI预判等离子体「暴走」,MIT等基于机器学习实现小样本下的等离子体动力学高精度预测
  • 网站链接推广工具网站提现功能怎么做