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

学习react小记

系列文章目录

目录

系列文章目录

前言

一、关于Hook

1、useEffect

1.1 如果在 useEffect 中没有声明第二个参数(依赖项数组),则会导致 useEffect 的行为有所不同。具体来说,以下是几种可能的情况: 

1.1.1  没有依赖项数组

1.1.2  性能影响

1.1.3 使用空数组 

1.1.4 包含依赖项

总结

总结


前言

时间比较紧迫都是边看代码边学习react,顺手记录一下帮助有需要的朋友。


一、关于Hook

1、useEffect

useEffect 是 React 中的副作用 Hook,允许你在组件渲染后执行某些副作用操作。它接收两个参数:

  • 第一个参数是一个函数,定义了当副作用触发时执行的逻辑。
  • 第二个参数是数组形式。useEffect 只有在依赖项发生变化时才会重新执行。useEffect 无法接受其他类型(如对象、字符串等)作为第二个参数。
  • 数组中的元素可以是任何可以追踪变化的值(如状态、props等),但它们都必须是可序列化的。如果依赖项是对象或数组,只有引用发生变化时,useEffect 才会重新执行。

譬如这里的依赖项是 defaultConfig,在这段代码中,当 defaultConfig 发生变化时,useEffect 内部的函数会被执行。这段代码的目的是确保当新的 defaultConfig 被提供时,它能够与当前的 inputs 合并,并且不会覆盖已有的输入值。这有助于在初次渲染或配置变化时,自动应用默认配置,同时保留用户已输入的内容。

 useEffect(() => {const isReady = defaultConfig && Object.keys(defaultConfig).length > 0if (isReady) {setInputs({...defaultConfig,...inputs,})}// eslint-disable-next-line react-hooks/exhaustive-deps}, [defaultConfig])

1.1 如果在 useEffect 中没有声明第二个参数(依赖项数组),则会导致 useEffect 的行为有所不同。具体来说,以下是几种可能的情况: 

1.1.1  没有依赖项数组

如果完全不传入第二个参数,useEffect 会在每次组件重新渲染时都执行。也就是说,每次组件的状态或属性变化导致组件重新渲染时,useEffect 都会被调用。这种情况下:

useEffect(() => {// 这段代码会在每次渲染时执行const isReady = defaultConfig && Object.keys(defaultConfig).length > 0;if (isReady) {setInputs({...defaultConfig,...inputs,});}
});

1.1.2  性能影响

  • 频繁执行:没有依赖项数组可能会导致不必要的性能开销,特别是在渲染频率较高的情况下。每次渲染都执行副作用,可能导致多次更新状态、重新计算等操作,从而影响性能。
  • 状态不一致:如果 inputs 的值也在这个 useEffect 中变化,可能会导致组件陷入无限循环,因为 setInputs 会导致组件重新渲染,从而再触发 useEffect

1.1.3 使用空数组 

如果传入一个空数组 [] 作为第二个参数,useEffect 只会在组件首次挂载时执行一次,之后不会再执行:

useEffect(() => {// 这段代码只会在组件挂载时执行一次const isReady = defaultConfig && Object.keys(defaultConfig).length > 0;if (isReady) {setInputs({...defaultConfig,...inputs,});}
}, []);

1.1.4 包含依赖项

当你传入 defaultConfig 作为依赖项时,useEffect 只会在 defaultConfig 变化时执行,这样可以确保副作用只在相关数据变化时被触发,从而保持组件的高效和响应性。

useEffect(() => {// 这段代码只会在 defaultConfig 变化时执行const isReady = defaultConfig && Object.keys(defaultConfig).length > 0;if (isReady) {setInputs({...defaultConfig,...inputs,});}
}, [defaultConfig]);

总结

  • 没有依赖项:每次渲染都会执行 useEffect,可能导致性能问题和状态不一致。
  • 空数组 []useEffect 只在组件首次挂载时执行。
  • 有依赖项(如 [defaultConfig]):useEffect 只在依赖项变化时执行,适用于需要在特定数据变化时执行副作用的情况。

总结

持续记录中....

相关文章:

  • Easy Excel从入门到精通!!!
  • IP与网关的关系
  • 免杀笔记 ---> 无痕Hook?硬件断点 Syscall!
  • C语言中的栈
  • 华为OD机试 - 对称美学(Python/JS/C/C++ 2024 E卷 100分)
  • 一文把数据架构讲明白
  • HTML5实现好看的唐朝服饰网站模板源码2
  • vue创建
  • 软件设计——随手笔记
  • ARM硬件知识补充
  • 工业制造场景中的设备管理深度解析
  • 新建flask项目,配置入口文件,启动项目
  • 网站建设中,常用的后台技术有哪些,他们分别擅长做什么网站平台
  • JAVA毕业设计185—基于Java+Springboot+vue3+小程序的校园网上商店小程序系统(源代码+数据库)
  • python装饰器用法
  • 网络传输文件的问题
  • python3.6+scrapy+mysql 爬虫实战
  • (三)从jvm层面了解线程的启动和停止
  • es6(二):字符串的扩展
  • Java深入 - 深入理解Java集合
  • storm drpc实例
  • Traffic-Sign Detection and Classification in the Wild 论文笔记
  • vue.js框架原理浅析
  • vue2.0项目引入element-ui
  • 记一次和乔布斯合作最难忘的经历
  • 开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
  • 看完九篇字体系列的文章,你还觉得我是在说字体?
  • 前端之Sass/Scss实战笔记
  • 一天一个设计模式之JS实现——适配器模式
  • Nginx惊现漏洞 百万网站面临“拖库”风险
  • Python 之网络式编程
  • 阿里云ACE认证之理解CDN技术
  • 数据库巡检项
  • 整理一些计算机基础知识!
  • #QT(TCP网络编程-服务端)
  • #QT项目实战(天气预报)
  • #在线报价接单​再坚持一下 明天是真的周六.出现货 实单来谈
  • ${ }的特别功能
  • (1)STL算法之遍历容器
  • (3)(3.5) 遥测无线电区域条例
  • (php伪随机数生成)[GWCTF 2019]枯燥的抽奖
  • (二)fiber的基本认识
  • (二十六)Java 数据结构
  • (三)Honghu Cloud云架构一定时调度平台
  • (三)uboot源码分析
  • (十三)MipMap
  • (十一)c52学习之旅-动态数码管
  • (原創) X61用戶,小心你的上蓋!! (NB) (ThinkPad) (X61)
  • (转) RFS+AutoItLibrary测试web对话框
  • (自用)gtest单元测试
  • .naturalWidth 和naturalHeight属性,
  • .NET Conf 2023 回顾 – 庆祝社区、创新和 .NET 8 的发布
  • .Net Memory Profiler的使用举例
  • .Net 代码性能 - (1)
  • .NET 实现 NTFS 文件系统的硬链接 mklink /J(Junction)