了解React中useCallback的依賴項快取和引用
P粉044526217
2023-08-15 19:29:37
<p>useCallback鉤子只緩存函數引用還是也緩存函數本身的值/結果?另外,在依賴陣列中使用ref是否真的產生任何效果,例如元件的ref?如果沒有,那麼有沒有辦法確保ref值的變更有適當的效果? </p>
<p>我原以為只有函數引用會被緩存,但在閱讀了一篇文章後得知,useCallback(fn, deps)等同於useMemo(() => fn, deps),我不確定這是否實際上是這種情況。此外,我嘗試使用元件的ref作為依賴項(如Video.js和react-slick),但我認為與其他依賴項相比,它沒有太大的影響。 </p>
是的,
useCallback
的目的是允許函數在渲染之間保持其引用,除非你指定的依賴項發生了變化。例如,如果你有一個函數
f(x,y)=>x y
,你可以使用空的依賴數組useCallback((x,y)=>x y,[ ])
,這個函數將永遠不會改變。它始終會產生一致的行為,因為它只使用其參數來解析輸出。但是,如果你有另一個函數h
和另一個外部值z
,它可能會發生變化,而h
定義為h(x ,y)=>x y z
,那麼你需要將z
包含在依賴項中,以便如果z
發生變化,從useCallback
返回的函數將具有新的引用。因此,
useCallback
的用途通常是當你傳遞函數時,它不會觸發子元件重新渲染,或者當你在子元件的useEffect
宣告中使用函數作為依賴項時。如果函數內部的操作很昂貴,那麼useCallback
就不太有用了,你應該單獨對結果進行記憶。關於
ref
的事情,我認為在依賴項中包含ref
並不會有任何作用,它就像數組為空一樣。也許如果ref
被儲存在狀態中,可能會有用,但我不太確定。這裡有一個連結https://stackblitz.com/edit/stackblitz-starters-wwyw9f?file=src/App.tsx,裡面有一些例子,也許有用。
如果可能會被刪除,我也可以將其貼過來。
希望能對你有幫助