欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React中的useEffect四種用法分享

 更新時(shí)間:2023年07月11日 11:18:16   作者:前端小張同學(xué)  
這篇文章主要給大家分享React中的useEffect四種用法,useEffect中 觸發(fā)更新,重復(fù)的 useEffect,依賴值觸發(fā)回調(diào),useEffect 的返回值,通過代碼示例介紹的非常詳細(xì),需要的朋友可以參考下

什么是 useEffect ?

官方解釋 : useEffect 是一個 React Hook,它允許你將組件與外部系統(tǒng)同步。

什么意思 ? 個人理解就是 它能根據(jù)不同的依賴值或者返回值,在不同的時(shí)機(jī)進(jìn)行執(zhí)行。

我們先來說說 第一種用法

1 : useEffect 中 觸發(fā)更新

示例1 : 當(dāng)我們在組件創(chuàng)建的過程,自動執(zhí)行某些操作的時(shí)候 , 那我們可以在函數(shù)式組件中這樣

錯誤示例

import { useEffect } from 'react'
function App () {
const [ count , setCount] = useState(0)
useEffect(()=> {
    initData()
})
const initData = () => {
    setCount(count + 1)
}
return ( <div> {count} </div> )
}

如果你這種用 useEffect 你會發(fā)現(xiàn) 什么問題 ?

當(dāng)我們組件 渲染完成去執(zhí)行 useEffect 調(diào)用 initData 函數(shù) 函數(shù)通過 setCount 設(shè)置值觸發(fā)更新,一旦更新 useEffect 又會在渲染的最后執(zhí)行,這樣就照成了 死循環(huán)

所以 你應(yīng)該這樣寫 ,傳入 useEffect 第二個參數(shù) 空數(shù)組,代表組件渲染過程中只執(zhí)行一次

正確示例

import { useEffect } from 'react'
function App () {
const [ count , setCount] = useState(0)
useEffect(()=> {
    initData()
}, [])
const initData = () => {
setCount(count + 1)
}
return ( <div> {count} </div> )
}

2 : 用法2 重復(fù)的 useEffect

示例2 : 當(dāng)我們在組件渲染的過程中 ,如果你寫了多個useEffect 它會怎么做 ?

import { useEffect, useState } from 'react';
function Effect() {
  const [count, setCount] = useState(0)
  useEffect(() => {
    console.log('111');
  })
  useEffect(() => {
    console.log('222');
  })
  return (<div> {count} </div>)
}
export default Effect

想當(dāng)然 , 它不會覆蓋前面的 useEffect ,會根據(jù)你的 編寫順序進(jìn)行收集,然后循環(huán)執(zhí)行(當(dāng)然這只是我的猜測,暫時(shí)還沒看react源碼)

3 :依賴值觸發(fā)回調(diào)

當(dāng)你想去依賴某些變量的時(shí)候去觸發(fā)回調(diào)函數(shù),你可以這樣。

import { useEffect, useState } from 'react';
function Effect() {
  const [count, setCount] = useState(0)
  useEffect(() => {
    console.log('count發(fā)生了變化最新值為' + count);
  }, [count])
  return (<div>
    <div>
      {count}
    </div>
    <button onClick={() => setCount(count + 1)}>加1</button>
  </div>)
}
export default Effect

當(dāng)你的第二個參數(shù)是數(shù)組,并且是依賴項(xiàng),組件初次渲染也會執(zhí)行,這是為什么呢 ?

解答 : 如果從 react useState Hook 來說,也就是 react 將你傳入的 默認(rèn)值 給你重新賦值了,所以發(fā)生了變化,因此 useEffect 發(fā)生了更新

4 :useEffect 的返回值

當(dāng)useEffect 傳入的 回調(diào)函數(shù)有返回值時(shí)并且為一個 函數(shù)的時(shí)候,它會怎么做?

import { useEffect, useState } from 'react';
const Room = () => {
  useEffect(() => {
    console.log("子組件渲染完成")
    return () => {
      console.log("子組件useeffect 回調(diào)函數(shù)執(zhí)行")
    }
  }, [])
  return (<div>
    這是我的房間 , 大家一起來玩呀
  </div>)
}
function Effect() {
  const [show, setShow] = useState(true)
  return (<div>
    <div>
      {show && <Room></Room>}
    </div>
    <button onClick={() => setShow(!show)}>加1</button>
  </div>)
}
export default Effect

解答 : useEffect函數(shù) 的返回值 如果是函數(shù)時(shí) 它會在組件銷毀的時(shí)候自動回調(diào)該函數(shù),你可以在該函數(shù)中做一些清理操作,等等

結(jié)束啦

好了,最后到這次本章了解的知識就到此結(jié)束了,如果有哪里寫的不對的地方或者有更好的使用方式,歡迎大家在評論區(qū)留言!

到此這篇關(guān)于React中的useEffect四種用法分享的文章就介紹到這了,更多相關(guān)React useEffect用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • react實(shí)現(xiàn)每隔60s刷新一次接口的示例代碼

    react實(shí)現(xiàn)每隔60s刷新一次接口的示例代碼

    本文主要介紹了react實(shí)現(xiàn)每隔60s刷新一次接口的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • React中hook函數(shù)與useState及useEffect的使用

    React中hook函數(shù)與useState及useEffect的使用

    這篇文章主要介紹了React中hook函數(shù)與useState及useEffect的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-10-10
  • 淺談React useDebounce 防抖原理

    淺談React useDebounce 防抖原理

    本文主要介紹了淺談React useDebounce 防抖原理,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • React自定義實(shí)現(xiàn)useWatch鉤子的示例

    React自定義實(shí)現(xiàn)useWatch鉤子的示例

    React中實(shí)現(xiàn)類似Vue watch的useWatch Hook,包含基礎(chǔ)監(jiān)聽、立即執(zhí)行、動態(tài)停止及深度比較四種方式,適用于不同場景,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-07-07
  • react中this指向的使用小結(jié)

    react中this指向的使用小結(jié)

    JavaScript中this指向取決于調(diào)用方式,React中需綁定this以防undefined,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2025-08-08
  • React中路由的參數(shù)傳遞路由的配置文件詳解

    React中路由的參數(shù)傳遞路由的配置文件詳解

    路由的配置文件目前我們所有的路由定義都是直接使用Route組件,并且添加屬性來完成的,路由的參數(shù)傳遞有二種方式這,兩種方式在Router6.x中都是提供的hook函數(shù)的API,?類組件需要通過高階組件的方式使用,本文通過示例代碼詳解講解,需要的朋友參考下吧
    2022-11-11
  • 解決react-connect中使用forwardRef遇到的問題

    解決react-connect中使用forwardRef遇到的問題

    這篇文章主要介紹了解決react-connect中使用forwardRef遇到的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • React Hooks常用場景的使用(小結(jié))

    React Hooks常用場景的使用(小結(jié))

    這篇文章主要介紹了React Hooks常用場景的使用,根據(jù)使用場景分別進(jìn)行舉例說明,幫助你認(rèn)識理解并可以熟練運(yùn)用 React Hooks 大部分特性,感興趣的可以了解一下
    2021-04-04
  • React使用ref進(jìn)行訪問DOM元素或組件

    React使用ref進(jìn)行訪問DOM元素或組件

    在 React 里,ref 就像是一個神奇的小助手,能讓你直接去訪問 DOM 元素或者組件實(shí)例,下面就跟隨小編一起來學(xué)習(xí)一下具體的使用方法吧
    2025-03-03
  • react使用useState修改對象或者數(shù)組的值無法改變視圖的問題

    react使用useState修改對象或者數(shù)組的值無法改變視圖的問題

    這篇文章主要介紹了react使用useState修改對象或者數(shù)組的值無法改變視圖的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08

最新評論