react中副作用函数(useEffect)详解

先简单说一下常见的useEffect使用方式 三种

useEffect(() => {
  // 副作用函数的内容
})  
 每次更新之后都要执行
--------------------
useEffect(() => {
  // 副作用函数的内容
}, []) 
初始化页面时 只执行第一次
--------------------
useEffect(() => {
  // 副作用函数的内容
}, [依赖项]) //依赖项可以有多个
1 初始执行一次 2 每次依赖项的值变化时执行

这是我们常用的方法

重点来了:

1. useEffect 只能是一个同步函数,不能使用 async

如果需要发送请求或者其他异步操作,需要额外加一个箭头函数包裹住

useEffect(()={
async () => {
    const res = awiat xxx()

   }
}, [])

2. 副作用函数的返回值

useEffect 函数是可以return的格式是下图,他可以返回一个函数,这个函数称为清理函数

useEffect(() => {
  // 副作用函数的内容

  return 副作用函数的返回值
}, [])

清理函数的执行时机: 清理函数会在组件卸载时以及下一次副作用函数调用之前执行

结合依赖项:上图中的清理函数只会在组件被卸载时调用,因为他的依赖项是空,只会在页面初始化的时候执行副作用函数不会执行清理函数,当组件卸载时执行清理函数

所以我们可以通过这一特性来模拟  componentWillUnmount 这个钩子函数,组件被销毁时执行

useEffect(()=>{
  return ()=>{
    // 做清理工作
  }
}, [])

  • 9
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在ReactuseEffect是一个用于执行副作用的钩子函数副作用是指每次组件更新都会执行的函数,可以用来取代生命周期方法。根据不同的使用方式,useEffect可以在组件挂载、更新和卸载时执行不同的逻辑。\[3\] 常见的useEffect使用方式有三种: 1. 每次更新都执行:不传递第二个参数,这会导致每次渲染都会运行useEffect。当它运行时,它获取数据并更新状态。一旦状态更新,组件将重新呈现,这将再次触发useEffect。\[1\] 2. 初始化页面时只执行一次:传递一个空数组作为第二个参数,这样useEffect只会在组件挂载时执行一次。\[2\] 3. 依赖项变化时执行:传递一个包含依赖项的数组作为第二个参数,当依赖项的值发生变化时,useEffect会执行。可以传入多个依赖项,只要有一项有变更就会执行effect。\[2\] 在使用useEffect时,可以根据需要返回一个清除函数,用于清除副作用。例如,设置一个定时器时,需要在组件卸载时关闭定时器,就可以在副作用返回一个函数来关闭定时器。\[3\] 总结来说,useEffect是一个非常有用的钩子函数,可以用于处理组件的副作用逻辑,取代了传统的生命周期方法。根据不同的使用方式,可以在组件挂载、更新和卸载时执行不同的逻辑。 #### 引用[.reference_title] - *1* [react useEffect详解](https://blog.csdn.net/weixin_45760365/article/details/124386573)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [react副作用函数(useEffect)详解](https://blog.csdn.net/DDAD9527/article/details/121294563)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [reactuseEffect](https://blog.csdn.net/zsm4623/article/details/127733367)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值