React Hooks —— useEffect篇

useEffect的设计是用来执行一段和当前渲染无关的副作用代码

组件(实例)的生命周期

  1. Mount/Initial render:第一次渲染组件实例,创建新的stateprops

  2. re-render(可选):

    • state改变时触发
    • props改变时触发
    • 父组件重新渲染时触发
    • Context改变时触发
  3. UnMount:组件实例被销毁并移除,stateprops被销毁

在哪里执行副作用?

回顾:副作用是任何"React组件和组件外部世界之间的交互"。我们也可以把副作用看作是"实际做一些事情的代码"。

比如:数据请求、设置订阅、设置计时器、手动访问DOM等。

React中,渲染逻辑中(Render Logic)不允许副作用的出现,我们有两种方式去执行副作用:

  1. Event Handlers(即事件的回调函数):通过事件触发,如onClickonSubmit
  2. useEffect:允许我们编写将在不同时刻运行的副作用代码:挂载、重新渲染或卸载

Event Handlers VS. useEffect

二者执行后会产生相同的效果,区别就是执行的时机不同

Event Handlers会在对应的事件触发时执行

useEffect会在组件挂载后(初始渲染)和随后的重新渲染后执行(由依赖数组决定),同时在组件卸载时会执行return返回的函数(Cleanup function

useEffect的依赖数组

默认情况下(不传入依赖数组),useEffect在每次渲染后执行。我们可以通过传入依赖数组来防止这种情况。

没有依赖数组,React不知道什么时候运行useEffect

每当依赖数组中的一个依赖项发生变化时,将再次执行useEffect

useEffect中使用的每个stateprop都必须包含在依赖数组中

useEffect是一种同步机制

useEffect就像一个事件监听器,监听一个依赖项的变化。每当依赖项发生变化时,它将再次执行该effect

同步与生命周期

我们可以在组件渲染或重新渲染时使用依赖数组来运行Effect

Effect和组件生命周期的对应关系

Cleanup Function

Cleanup FunctionuseEffect返回的函数,这个函数会useEffect再次执行时和组件卸载时执行

每个Effect应该只做一件事!为每个副作用使用一个useEffect钩子。这使得Effect更容易清理

理解

useEffect和生命周期无关,他是函数组件形态下的另一种设计模式,只能说他能解决我们过去认知中的使用生命周期的一些问题。所以我们首先要转变的思想就是忘掉生命周期,将思考放在如何通过函数组件的重复执行解决上。------奇舞精选

相关推荐
一个处女座的程序猿O(∩_∩)O8 分钟前
React Router 路由模式详解:HashRouter vs BrowserRouter
前端·react.js·前端框架
Caster_Z35 分钟前
WinServer安装NPM(Nginx Proxy Manager),并设置反向代理和开启https
前端·nginx·npm
顾安r36 分钟前
11.22 脚本 手机termux项目分析(bash)
前端·python·stm32·flask·bash
是你的小橘呀1 小时前
JavaScript 原型链解密:原来 proto 和 prototype 这么好懂
前端·javascript·前端框架
ohyeah1 小时前
使用 LocalStorage 实现本地待办事项(To-Do)列表
前端·javascript
Jing_Rainbow1 小时前
【前端三剑客-6/Lesson11(2025-10-28)构建现代响应式网页:从 HTML 到 CSS 弹性布局再到 JavaScript 交互的完整指南 🌈
前端·javascript
非专业程序员1 小时前
精读 GitHub - servo 浏览器(一)
前端·ios·rust
Yanni4Night1 小时前
掌握 JS 中迭代器的未来用法
前端·javascript
Irene19911 小时前
Element UI 及其 Vue 3 版本 Element Plus 发展现状
前端·vue.js·ui
Account_Ray1 小时前
vue3 的专属二维码组件 vue3-next-qrcode 迎来 4.0.0 版本
前端·vue.js·nuxt.js