详解 useEffect return 内外的代码执行顺序

参考代码

jsx 复制代码
    import React, { useEffect, useState } from 'react'
    import { Link } from 'react-router-dom'

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

      useEffect(() => {
        console.log('无依赖---------------------------', count)
        return () => {
          console.log('执行  无依赖  时的return的函数')
        }
      })
      useEffect(() => {
        console.log('依赖为[]------------------------', count)
        return () => {
          console.log('执行 依赖为[]  时的return的函数')
        }
      }, [])
      useEffect(() => {
        console.log('依赖为[count]------------------------', count)
        return () => {
          console.log('执行 依赖为[count]  时的return的函数')
        }
      }, [count])
      return (
        <div>
          <p>count的值为: {count} </p>
          <button onClick={() => setCount(count + 1)}>add</button>

          <Link to="/management">About</Link>
        </div>
      )
    }

初次加载页面结果如下

可以看到首次组件加载时,return 都没有执行

修改依赖项之后

修改依赖项会先执行无依赖和依赖的 return,再执行 return 之外的,没有执行依赖项为空数组的情况。

跳转路由之后

可以看到路由跳转时,三种情况的 return 都执行了

总结

  1. 当 useEffect 被再次执行时会先清理副作用执行 return,再执行 return 之外的,可以理解为只要 useEffect 被再次执行,都会执行 return
  2. 当组件销毁时,不管是否有依赖项,useEffect 的 return 都会被执行去清理副作用
    react版本: "^18.2.0"

代码参考:useEffect有依赖项和没有依赖项时return内外的代码执行顺序_useeffect return-CSDN博客

相关推荐
majingming1236 小时前
FUNCTION
java·前端·javascript
A_nanda6 小时前
Vue项目升级
前端·vue3·vue2
SuperEugene6 小时前
Axios 接口请求规范实战:请求参数 / 响应处理 / 异常兜底,避坑中后台 API 调用混乱|API 与异步请求规范篇
开发语言·前端·javascript·vue.js·前端框架·axios
abigale037 小时前
【浏览器 API / 网络请求 / 文件处理】前端文件上传全流程:从基础上传到断点续传
前端·typescript·文件上传·vue cli
子兮曰7 小时前
Bun v1.3.11 官方更新全整理:新增功能、关键修复与升级验证
javascript·node.js·bun
Setsuna_F_Seiei7 小时前
AI 对话应用之页面滚动交互的实现
前端·javascript·ai编程
新缸中之脑8 小时前
追踪来自Agent的Web 流量
前端
wefly20178 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
英俊潇洒美少年9 小时前
vue如何实现react useDeferredvalue和useTransition的效果
前端·vue.js·react.js
kyriewen119 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript