亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

React中閉包陷阱的幾種情及解決方案

 更新時(shí)間:2024年07月25日 09:48:55   作者:每天工作十小時(shí)  
在react中我們使用其提供的Hooks中的useState,useEffect,useCallback 時(shí),可能會(huì)造成閉包陷阱,下面我們來(lái)看一下出現(xiàn)的情況以及如何解決,感興趣的小伙伴跟著小編一起來(lái)看看吧

什么是閉包?

閉包是指在一個(gè)函數(shù)內(nèi)部包裹函數(shù),并且內(nèi)部函數(shù)總能訪問(wèn)外部函數(shù)的變量。

function f1(){
    var num = 10,
    function f2(){
        alert(num)  // 10
    }
}

特點(diǎn):

1:函數(shù)套函數(shù);

2:內(nèi)部函數(shù)可以直接使用外部函數(shù)的局部變量或參數(shù);

3:變量或參數(shù)不會(huì)被垃圾回收機(jī)制回收 GC

缺點(diǎn):常駐內(nèi)存 會(huì)增大內(nèi)存的使用量 使用不當(dāng)會(huì)造成內(nèi)存泄露。

閉包陷阱以及如何解決

在react中我們使用其提供的Hooks中的useState,useEffect,useCallback 時(shí),可能會(huì)造成閉包陷阱,下面我們來(lái)看一下出現(xiàn)的情況以及如何解決

useState【異步陷阱】

 const [num, setNum] = useState(0)
  const jia = () => {
    setNum(num + 1)
    console.log(num);
  }
  return (
    <div>
      <h1>{num}</h1>
      <button onClick={() => jia()}>點(diǎn)我+1</button>
    </div>
  )

問(wèn)題:當(dāng)我們點(diǎn)擊button按鈕時(shí),會(huì)發(fā)現(xiàn)值在持續(xù) +1 ,但是打印的值始終都是上一次點(diǎn)擊的值,

因?yàn)閡seState修改值是異步更新,無(wú)法獲取更新后的值

解決方案:

const [num, setNum] = useState(0)
  const numRef = useRef()
  const jia = () => {
    setNum(num + 1)
    setTimeout(() => {  //模擬異步操作
      console.log(numRef.current.innerText);
    }, 0)
  }
  return (
    <div>
      <h1 ref={numRef}>{num}</h1>
      <button onClick={() => jia()}>點(diǎn)我+1</button>
    </div>
  )

使用useRef來(lái)獲取元素的值 

useEffect【過(guò)期問(wèn)題】

const [num, setNum] = useState(0)
 
  useEffect(() => {
    setInterval(() => {
      setNum(num + 1)
    }, 1000)
  }, [])
 
  return (
    <div>
      <h1>{num}</h1>
    </div>
  )

問(wèn)題:useEffect是在頁(yè)面加載時(shí)執(zhí)行,如果第二個(gè)參數(shù)是一個(gè)空數(shù)組,則只執(zhí)行一次,所以我們可以看到頁(yè)面始終顯示的都是1

解決方案:

const [num, setNum] = useState(0)
 
  useEffect(() => {
    let time = setInterval(() => {
      setNum(num + 1)
      clearInterval(time)
    }, 1000)
  }, [num])
 
  return (
    <div>
      <h1>{num}</h1>
    </div>
  )

我們可以通過(guò)在空數(shù)組中傳入依賴項(xiàng),使得useEffect中的邏輯在num每次更改時(shí)都會(huì)執(zhí)行,并在每次執(zhí)行后都清楚掉定時(shí)器

useCallback【緩存問(wèn)題】

useCallback是用來(lái)進(jìn)行優(yōu)化的函數(shù),他的作用是返回一個(gè)記憶化的回調(diào)函數(shù),該回調(diào)函數(shù)僅在其依賴項(xiàng)發(fā)生變化時(shí)才會(huì)更新。這在處理子組件的 props 或者優(yōu)化事件處理函數(shù)等場(chǎng)景中非常有用。

我們?cè)诟附M件向子組件傳遞數(shù)據(jù),并在父組件修改值,我們會(huì)發(fā)現(xiàn),子組件的useCallback中打印的一直都是0

解決方案:我們?cè)趗seCallback的空數(shù)組中,傳入我們的依賴項(xiàng) props.num 這樣每次props.num 發(fā)生改變就會(huì)重新執(zhí)行代碼

到此這篇關(guān)于React中閉包陷阱的幾種情及解決方法的文章就介紹到這了,更多相關(guān)React閉包陷阱內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React Grid Layout基礎(chǔ)使用示例教程

    React Grid Layout基礎(chǔ)使用示例教程

    React Grid Layout是一個(gè)用于在React應(yīng)用程序中創(chuàng)建可拖拽和可調(diào)整大小的網(wǎng)格布局的庫(kù),通過(guò)使用React Grid Layout,我們可以輕松地創(chuàng)建自適應(yīng)的網(wǎng)格布局,并實(shí)現(xiàn)拖拽和調(diào)整大小的功能,本文介紹了React Grid Layout的基礎(chǔ)使用方法,感興趣的朋友一起看看吧
    2024-02-02
  • React跨端動(dòng)態(tài)化之從JS引擎到RN落地詳解

    React跨端動(dòng)態(tài)化之從JS引擎到RN落地詳解

    這篇文章主要為大家介紹了React跨端動(dòng)態(tài)化之從JS引擎到RN落地,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • redux的原理、工作流程及其應(yīng)用方式

    redux的原理、工作流程及其應(yīng)用方式

    這篇文章主要介紹了redux的原理、工作流程及其應(yīng)用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 再次談?wù)揜eact.js實(shí)現(xiàn)原生js拖拽效果引起的一系列問(wèn)題

    再次談?wù)揜eact.js實(shí)現(xiàn)原生js拖拽效果引起的一系列問(wèn)題

    React 起源于 Facebook 的內(nèi)部項(xiàng)目,因?yàn)樵摴緦?duì)市場(chǎng)上所有 JavaScript MVC 框架,都不滿意,就決定自己寫一套,用來(lái)架設(shè) Instagram 的網(wǎng)站.本文給大家介紹React.js實(shí)現(xiàn)原生js拖拽效果,需要的朋友一起學(xué)習(xí)吧
    2016-04-04
  • 詳解react如何實(shí)現(xiàn)復(fù)合組件

    詳解react如何實(shí)現(xiàn)復(fù)合組件

    在一些react項(xiàng)目開發(fā)中,常常會(huì)出現(xiàn)一些組合的情況出現(xiàn),這篇文章主要為大家介紹了復(fù)合組件的具體實(shí)現(xiàn),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-10-10
  • React createElement方法使用原理分析介紹

    React createElement方法使用原理分析介紹

    這篇文章主要為大家介紹了React的createElement方法源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • react 不用插件實(shí)現(xiàn)數(shù)字滾動(dòng)的效果示例

    react 不用插件實(shí)現(xiàn)數(shù)字滾動(dòng)的效果示例

    這篇文章主要介紹了react 不用插件實(shí)現(xiàn)數(shù)字滾動(dòng)的效果示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 詳解React setState數(shù)據(jù)更新機(jī)制

    詳解React setState數(shù)據(jù)更新機(jī)制

    這篇文章主要介紹了React setState數(shù)據(jù)更新機(jī)制的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用React框架,感興趣的朋友可以了解下
    2021-04-04
  • react native 原生模塊橋接的簡(jiǎn)單說(shuō)明小結(jié)

    react native 原生模塊橋接的簡(jiǎn)單說(shuō)明小結(jié)

    這篇文章主要介紹了react native 原生模塊橋接的簡(jiǎn)單說(shuō)明小結(jié),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-02-02
  • 記錄React使用connect后,ref.current為null問(wèn)題及解決

    記錄React使用connect后,ref.current為null問(wèn)題及解決

    記錄React使用connect后,ref.current為null問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-05-05

最新評(píng)論