React中閉包陷阱的幾種情及解決方案
什么是閉包?
閉包是指在一個函數(shù)內部包裹函數(shù),并且內部函數(shù)總能訪問外部函數(shù)的變量。
function f1(){ var num = 10, function f2(){ alert(num) // 10 } }
特點:
1:函數(shù)套函數(shù);
2:內部函數(shù)可以直接使用外部函數(shù)的局部變量或參數(shù);
3:變量或參數(shù)不會被垃圾回收機制回收 GC
缺點:常駐內存 會增大內存的使用量 使用不當會造成內存泄露。
閉包陷阱以及如何解決
在react中我們使用其提供的Hooks中的useState,useEffect,useCallback 時,可能會造成閉包陷阱,下面我們來看一下出現(xiàn)的情況以及如何解決
useState【異步陷阱】
const [num, setNum] = useState(0) const jia = () => { setNum(num + 1) console.log(num); } return ( <div> <h1>{num}</h1> <button onClick={() => jia()}>點我+1</button> </div> )
問題:當我們點擊button按鈕時,會發(fā)現(xiàn)值在持續(xù) +1 ,但是打印的值始終都是上一次點擊的值,
因為useState修改值是異步更新,無法獲取更新后的值
解決方案:
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()}>點我+1</button> </div> )
使用useRef來獲取元素的值
useEffect【過期問題】
const [num, setNum] = useState(0) useEffect(() => { setInterval(() => { setNum(num + 1) }, 1000) }, []) return ( <div> <h1>{num}</h1> </div> )
問題:useEffect是在頁面加載時執(zhí)行,如果第二個參數(shù)是一個空數(shù)組,則只執(zhí)行一次,所以我們可以看到頁面始終顯示的都是1
解決方案:
const [num, setNum] = useState(0) useEffect(() => { let time = setInterval(() => { setNum(num + 1) clearInterval(time) }, 1000) }, [num]) return ( <div> <h1>{num}</h1> </div> )
我們可以通過在空數(shù)組中傳入依賴項,使得useEffect中的邏輯在num每次更改時都會執(zhí)行,并在每次執(zhí)行后都清楚掉定時器
useCallback【緩存問題】
useCallback是用來進行優(yōu)化的函數(shù),他的作用是返回一個記憶化的回調函數(shù),該回調函數(shù)僅在其依賴項發(fā)生變化時才會更新。這在處理子組件的 props 或者優(yōu)化事件處理函數(shù)等場景中非常有用。
我們在父組件向子組件傳遞數(shù)據(jù),并在父組件修改值,我們會發(fā)現(xiàn),子組件的useCallback中打印的一直都是0
解決方案:我們在useCallback的空數(shù)組中,傳入我們的依賴項 props.num 這樣每次props.num 發(fā)生改變就會重新執(zhí)行代碼
到此這篇關于React中閉包陷阱的幾種情及解決方法的文章就介紹到這了,更多相關React閉包陷阱內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
再次談論React.js實現(xiàn)原生js拖拽效果引起的一系列問題
React 起源于 Facebook 的內部項目,因為該公司對市場上所有 JavaScript MVC 框架,都不滿意,就決定自己寫一套,用來架設 Instagram 的網站.本文給大家介紹React.js實現(xiàn)原生js拖拽效果,需要的朋友一起學習吧2016-04-04react 不用插件實現(xiàn)數(shù)字滾動的效果示例
這篇文章主要介紹了react 不用插件實現(xiàn)數(shù)字滾動的效果示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-04-04詳解React setState數(shù)據(jù)更新機制
這篇文章主要介紹了React setState數(shù)據(jù)更新機制的相關資料,幫助大家更好的理解和學習使用React框架,感興趣的朋友可以了解下2021-04-04記錄React使用connect后,ref.current為null問題及解決
記錄React使用connect后,ref.current為null問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-05-05