日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

useCallback 使用的四個階段,你都知道嗎?

來源: 責編: 時間:2024-01-18 09:40:32 315觀看
導讀非 React 使用者估計看了都要搖頭啊。一個破回調函數(shù)的運用,居然能折騰出來這么多事。一大堆文章都在探討如何使用它更合理。事實上確實如此,在 React 獨特的單向數(shù)據(jù)流刷新機制下,對于 useCallback 認知的逐漸深入實際

3Mc28資訊網(wǎng)——每日最新資訊28at.com

非 React 使用者估計看了都要搖頭啊。一個破回調函數(shù)的運用,居然能折騰出來這么多事。一大堆文章都在探討如何使用它更合理。事實上確實如此,在 React 獨特的單向數(shù)據(jù)流刷新機制下,對于 useCallback 認知的逐漸深入實際上也代表著對 React 本身這個機制的理解更進一步,因此在你徹底消化 React 刷新機制之前,這個過程中的每一個知識點可能都有巨大的探討空間3Mc28資訊網(wǎng)——每日最新資訊28at.com

前幾天我的一位學生跟我探討了一種 useCallback 的用法,他的想法是:當我們在封裝開源工具庫時,對自定義 hook 中暴露出來的鉤子函數(shù)使用 useCallback 緩存。因為我們并不確定使用者是否需要一個引用穩(wěn)定的鉤子函數(shù),他們有可能是需要的,因此用 useCallback 來包一層是有意義的。但是他并不確定這樣的做法是否合適,是否具備較大的正向收益。3Mc28資訊網(wǎng)——每日最新資訊28at.com

那么我就借著這個案例,來跟大家探討一下,我們在 React 進階的過程中,使用 useCallback 的四個階段。3Mc28資訊網(wǎng)——每日最新資訊28at.com

階段一:敬畏

這個時候你還是一個初學者,對 React 的理解還不夠深刻不夠全面,但是常常看到文章,或者聽別人說 useCallback 跟性能優(yōu)化有關,可對于你而言,你并不是非常清楚它跟性能優(yōu)化的具體關系在哪里,想知道,但不知道或者不夠確定,因此對這個 hook api 有一種敬畏之心,各個論壇里對于 useCallback 的介紹很多很嘲雜,但你不敢隨便用。3Mc28資訊網(wǎng)——每日最新資訊28at.com

因此你很想去看看別人的代碼里,useCallback 是怎么用的,是在什么場景下使用的,但是想要看到別人的代碼也并不容易,因此你可能會在這個階段徘徊。3Mc28資訊網(wǎng)——每日最新資訊28at.com

階段二:懂了

隨著學習的深入,你逐漸開始深入理解了 React 的單向數(shù)據(jù)流機制,也對 React 的使用更加熟練,知道 React 經(jīng)常會存在許多 re-render,你終于搞懂了 useCallback 的使用場景,它結合 React.memo 能夠緩存組件,避免組件的冗余 re-render。3Mc28資訊網(wǎng)——每日最新資訊28at.com

于是你在項目中大量的使用了他們,就像當初 PureComponent 一樣,你恨不得每個函數(shù)都用 useCallback 套一層,以確保自己的項目能最大限度減少 re-render,從而達到一個極致的性能體驗。3Mc28資訊網(wǎng)——每日最新資訊28at.com

function App() {  ...  const clickHankler = useCallback(() => {    ...  }, [count])  const onOpen = useCallback(() => {    ...  }, [])    ...}

但是不管你用還不用,是大量使用還是大量不使用,從頁面的運行結果中,都看不出來你這樣寫帶來了什么實質的提升,甚至你有可能在依賴項的使用上感到難受,因為閉包的影響導致實際運行結果跟你預想的有出入。但是你能明確感受到 re-render 次數(shù)減少了。因此這個階段你非常堅信自己達到了性能優(yōu)化的目的。3Mc28資訊網(wǎng)——每日最新資訊28at.com

直到一次偶然的面試中,你被面試官一個問題問得啞口無言:只用 useCallback 能達到減少 re-render 的次數(shù)嗎?為什么?3Mc28資訊網(wǎng)——每日最新資訊28at.com

階段三:精通3Mc28資訊網(wǎng)——每日最新資訊28at.com

聽了我的直播分享,徹底搞懂了 React 的底層 DIFF 機制,你發(fā)現(xiàn)原來在 React 底層機制的邏輯下,我們大量的緩存工作其實是沒有必要的。React.memo 也有不小的使用成本,有的時候他的損耗不一定比 re-render 更低,于是你懂得了如何在項目中合理的使用 useCallback + React.memo,一通優(yōu)化下來,項目里的 useCallback 都被刪得差不多了,只在關鍵位置剩下幾個。3Mc28資訊網(wǎng)——每日最新資訊28at.com

優(yōu)化的結果很理想,re-render 的情況不僅沒有變多,項目還減負了,性能又得到了提升,你很開心很有成就感。心想我終于又有了成長,再次遇到上次那個面試官,我必定能吊打他。3Mc28資訊網(wǎng)——每日最新資訊28at.com

階段四:貫通3Mc28資訊網(wǎng)——每日最新資訊28at.com

你終于明白了 useCallback 只是一個非常普通的記憶函數(shù)。在 React hooks 特定的機制下記憶函數(shù)本身就被大量運用。React 的許多 hook 都有類似的記憶能力,useCallback 只是最普通的那一個,另外的 hook 都在記憶能力的基礎之上又添加了一些別的語義。3Mc28資訊網(wǎng)——每日最新資訊28at.com

useStateuseEffectuseLayoutEffectuseCallbackuseMemouseRefuseReduceruseSyncExternalStore...

這個階段你不再特殊看待他,在你的知識結構里面你也不再特意的把他跟性能優(yōu)化掛上勾,而是把他標記為一個記憶函數(shù),他能夠保持一個函數(shù)的引用,當你在 React 這個不穩(wěn)定的上下文環(huán)境中過,需要一個穩(wěn)定的引用時,你才會使用 useCallback。3Mc28資訊網(wǎng)——每日最新資訊28at.com

因此,當你在封裝一個開源工具庫時,你想到了你會對外拋出一個鉤子函數(shù),但是你并不確定使用者會如何使用這個鉤子函數(shù),使用者有可能會把他傳遞給子組件,此時如果鉤子函數(shù)引用不穩(wěn),那么就有可能導致子組件 re-render。3Mc28資訊網(wǎng)——每日最新資訊28at.com

例如在我們前面學習自定義 hook 的文章中,我們封裝了一個 hook useFetch,代碼如下:3Mc28資訊網(wǎng)——每日最新資訊28at.com

import { useState, useRef, useLayoutEffect } from 'react'type API<T, P> = (param?: P) => Promise<T>export default function useFetch<T, P>(api: API<T, P>) {  const param = useRef<P>()  const [list, setList] = useState<T>()  const [error, setError] = useState('')  const [loading, setLoading] = useState(true)  function getList() {    api(param.current).then(res => {      setList(res)      setLoading(false)      setError('')    }).catch(err => {      setLoading(false)      setError(err)    })  }  useLayoutEffect(() => {    loading && getList()  }, [loading])  return {     param,     setParam: (p: P) => param.current = p,    list,     error,     loading,     setLoading   }}

我們可以看到代碼里,在這個自定義 hook 中,返回了兩個鉤子函數(shù) setLoading setParam。3Mc28資訊網(wǎng)——每日最新資訊28at.com

為了驗證他們的引用是否穩(wěn)定,我們在使用 useFectch 的組件中使用如下代碼來驗證函數(shù)的引用是否發(fā)生了變化。3Mc28資訊網(wǎng)——每日最新資訊28at.com

useEffect(() => {  console.log('setLoading')}, [setLoading])

驗證結果非常神奇,setLoading 的引用居然非常的穩(wěn)定。但對于此時的你來說,這并沒有什么值得奇怪的地方。因為他是直接從 useState 中獲取出來的。useState 本身就具備記憶能力,因此對于 setLoading 來說,我們不再需要想任何辦法來讓他的引用來保持穩(wěn)定。3Mc28資訊網(wǎng)——每日最新資訊28at.com

setParam 跟預期一樣,一點也不穩(wěn)定,每次狀態(tài)變化,他的引用都會發(fā)生變化。因為在定義它的時候,每次都是新生成的函數(shù)給他賦值。3Mc28資訊網(wǎng)——每日最新資訊28at.com

return {     param, +    setParam: (p: P) => param.current = p,    list,     error,     loading,     setLoading   }

此時到了 useCallback 大展身手的時候了,我們使用 useCallback 包一層。3Mc28資訊網(wǎng)——每日最新資訊28at.com

return {     param, -    setParam: (p: P) => param.current = p,+    setParam: useCallback((p: P) => param.current = p, []),    list,     error,     loading,     setLoading   }

再次驗證,發(fā)現(xiàn)引用果然變穩(wěn)定了。nice。3Mc28資訊網(wǎng)——每日最新資訊28at.com

但是你害怕這樣做有什么你沒想到的點,因為 useCallback 太善變了,所以你就跑來跟我溝通,想確定一下這樣子做到底能不能帶來很大的正向收益。3Mc28資訊網(wǎng)——每日最新資訊28at.com

萬萬沒想到,我一開口就說:沒必要。3Mc28資訊網(wǎng)——每日最新資訊28at.com

我引導你去看一下引用穩(wěn)定的 setLoading 是如何使用的,你就去翻了一下代碼,結果一看,壞事了,setLoading 因為傳了一個參數(shù),導致在使用的時候又套了一層函數(shù)。3Mc28資訊網(wǎng)——每日最新資訊28at.com

代碼如下。此時 onClick 接收到的還是一個引用不穩(wěn)定的匿名函數(shù)... setLoading 的引用白考慮了。3Mc28資訊網(wǎng)——每日最新資訊28at.com

<Button  className={s.button}  onClick={() => setLoading(true)}>

然后你又看了一眼 setParam 的使用,還是這么個情況。3Mc28資訊網(wǎng)——每日最新資訊28at.com

<input  className={s.input}  placeholder="請輸入您要搜索的內容"  onChange={(e) => setParam(e.target.value)}/>

最后一想,發(fā)現(xiàn)好像 useCallback 又做了無用功。3Mc28資訊網(wǎng)——每日最新資訊28at.com

至此,你徹底悟了。3Mc28資訊網(wǎng)——每日最新資訊28at.com

就說總有一種不確定感,原來少考慮了一步。當自定義 hook 傳出來的 函數(shù)在執(zhí)行時需要傳入?yún)?shù)時,就不得不在這個函數(shù)外面包一層匿名函數(shù),再傳遞給子組件使用,如果它不需要參數(shù),useCallback 才會發(fā)揮它的效果。3Mc28資訊網(wǎng)——每日最新資訊28at.com

function useRouter() {  const { dispatch } = useContext(RouterStateContext);  const navigate = useCallback((url) => {    dispatch({ type: 'navigate', url });  }, [dispatch]);  const goBack = useCallback(() => {    dispatch({ type: 'back' });  }, [dispatch]);  return {    navigate,    goBack,  };}
const {goBack} = useRouter()... <Child onBack={goBack}  />

當真是真是步步驚心啊。3Mc28資訊網(wǎng)——每日最新資訊28at.com

你終于悟到了要結合實際使用的場景去考慮使用 useCallback 的準確時機,自此,融匯貫通成就達成。3Mc28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-64102-0.htmluseCallback 使用的四個階段,你都知道嗎?

聲明:本網(wǎng)頁內容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 掌握Python八種繪圖類型帶你深入時間序列數(shù)據(jù)分析

下一篇: 2024年不容錯過的十個開發(fā)框架

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
欧美主播一区二区三区美女 久久精品人| 亚洲第一精品福利| 欧美国产精品人人做人人爱| 欧美国产日韩一区二区| 国产精品黄色| 国产一区二区三区在线免费观看 | 亚洲国产欧美一区| 亚洲美女黄色| 午夜一级在线看亚洲| 老司机精品福利视频| 欧美日韩综合精品| 国模私拍视频一区| 99精品视频一区二区三区| 欧美一区二区三区免费观看视频| 麻豆成人在线| 国产精品久久久久久影院8一贰佰| 黄色国产精品| 亚洲网站视频| 美女网站在线免费欧美精品| 欧美午夜视频在线观看| 尤物精品在线| 午夜精品区一区二区三| 欧美福利视频在线观看| 国产欧美日韩亚洲一区二区三区| 亚洲国产成人午夜在线一区| 亚洲欧美精品一区| 欧美激情a∨在线视频播放| 国产欧美日韩一区二区三区在线观看 | 国产欧美日韩激情| 亚洲人成在线观看一区二区| 午夜日韩av| 欧美日韩国产综合视频在线观看 | 亚洲一区欧美| 欧美国产日韩a欧美在线观看| 国产精品亚洲激情| 亚洲精品乱码久久久久久日本蜜臀 | 日韩视频专区| 久久久久久久久久看片| 国产精品对白刺激久久久| 在线看无码的免费网站| 亚洲欧美在线观看| 欧美日韩亚洲系列| 亚洲国产精品一区二区尤物区| 欧美一区二区视频在线观看2020 | 欧美久久在线| 在线观看成人av电影| 欧美亚洲一区| 国产精品vip| 日韩午夜激情av| 欧美91精品| 一区二区三区无毛| 久久aⅴ国产欧美74aaa| 国产精品毛片在线看| 一本一本大道香蕉久在线精品| 欧美wwwwww| 狠狠色综合色区| 欧美中文在线免费| 国产精品网站在线播放| 亚洲视频一区二区在线观看| 欧美另类变人与禽xxxxx| 亚洲国产高清一区二区三区| 久久另类ts人妖一区二区| 国产亚洲精品aa午夜观看| 中文av字幕一区| 欧美日韩国产系列| 日韩午夜在线视频| 欧美精品性视频| 亚洲国产精品成人va在线观看| 久久久天天操| 精品成人乱色一区二区| 久久久亚洲高清| 精品999网站| 久久这里有精品视频| 一区二区在线观看av| 久久久亚洲国产美女国产盗摄| 国产中文一区| 久久久噜噜噜久久| 伊人男人综合视频网| 久久综合久久久久88| 在线视频国产日韩| 欧美成人国产va精品日本一级| 亚洲国产精品久久久久久女王| 免费人成网站在线观看欧美高清| 亚洲国产精品123| 欧美顶级大胆免费视频| 亚洲日本中文字幕| 欧美日韩99| 一区二区三区日韩欧美| 国产精品久久久久久久浪潮网站| 亚洲综合电影| 国产亚洲精品自拍| 久热爱精品视频线路一| 亚洲人成在线免费观看| 欧美日韩一区二区在线观看视频| 亚洲图色在线| 国产亚洲综合性久久久影院| 久久亚裔精品欧美| 亚洲精品日韩综合观看成人91| 欧美日韩高清在线一区| 亚洲午夜精品福利| 国产视频精品va久久久久久| 久久资源av| 日韩五码在线| 国产农村妇女毛片精品久久莱园子| 久久国产天堂福利天堂| 亚洲第一在线综合在线| 欧美日本在线视频| 午夜国产精品视频免费体验区| 国产自产2019最新不卡| 欧美成黄导航| 亚洲一区二区不卡免费| 国产主播在线一区| 欧美激情日韩| 亚洲欧美一区二区三区久久| 精品1区2区3区4区| 欧美日韩美女在线| 欧美一区二区在线免费播放| 伊甸园精品99久久久久久| 欧美精品一区在线| 欧美一区二区视频97| 亚洲国产影院| 国产精品日韩高清| 久久一区二区三区超碰国产精品| 亚洲美女少妇无套啪啪呻吟| 国产精品一区三区| 欧美成人a∨高清免费观看| 亚洲一区二区在线视频| 在线观看日韩国产| 国产精品久久久久久久午夜| 久久三级福利| 亚洲一区二区三区欧美| 经典三级久久| 国产精品v亚洲精品v日韩精品| 久久精品国产2020观看福利| 亚洲精选91| 国产专区欧美专区| 欧美日韩一区二区三| 久久久免费精品视频| 亚洲视频一区二区| 亚洲国产经典视频| 国产欧美日本| 欧美日韩免费一区二区三区视频| 久久高清免费观看| 一区二区三区www| 加勒比av一区二区| 国产精品美女久久福利网站| 牛牛精品成人免费视频| 亚洲欧美精品一区| 亚洲精品欧美激情| 韩国自拍一区| 国产精品日韩精品欧美在线| 欧美成在线观看| 久久精品国产第一区二区三区最新章节| 亚洲精品一区在线观看| 国产综合在线视频| 国产精品久久国产精品99gif| 欧美v日韩v国产v| 久久国产精品亚洲va麻豆| 一区二区三区国产| 亚洲国产清纯| 黑人巨大精品欧美一区二区小视频 | 欧美激情精品久久久久久大尺度| 欧美亚洲免费电影| 这里只有精品视频| 亚洲精品精选| 在线观看日韩av| 国产日韩欧美中文| 国产精品激情电影| 欧美日韩一区二区视频在线观看| 猛干欧美女孩| 久久视频国产精品免费视频在线| 午夜精品久久久久久久白皮肤 | 国产私拍一区| 欧美午夜久久| 欧美电影专区| 久久亚洲私人国产精品va媚药| 新狼窝色av性久久久久久| 一区二区激情| 亚洲精品一区二区三区婷婷月 | 久久精品一区二区三区不卡牛牛| 亚洲永久免费观看| 中国成人在线视频| 一区二区欧美在线观看| 亚洲乱码国产乱码精品精可以看| 亚洲高清资源| 亚洲国产精品激情在线观看| 精品成人一区二区| 精品成人国产| 在线 亚洲欧美在线综合一区| 国产一区白浆| 国产综合精品一区| 国产一区二区在线免费观看| 国产亚洲激情视频在线| 国产视频在线一区二区| 国产日韩欧美在线一区| 国产婷婷色一区二区三区| 国产日产亚洲精品系列| 国产日韩精品在线播放| 国产美女在线精品免费观看| 国产噜噜噜噜噜久久久久久久久| 国产精品爽黄69| 国产日产欧美a一级在线| 国产亚洲精久久久久久| 黄色亚洲在线|