千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機構(gòu)

手機站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進入千鋒手機站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  應(yīng)聘面試  >  html5面試題  > 說說在使用Hooks的過程中,需要注意什么

說說在使用Hooks的過程中,需要注意什么

來源:千鋒教育
發(fā)布人:syq
時間: 2022-11-16 16:58:53 1668589133

  1 首先注意到就是 useState

  里面方法是異步的,所以不要在后面連續(xù)調(diào)用,由于react方法是批量異步調(diào)用,并不是每次調(diào)用修改方法都執(zhí)行,所以需要用到callback寫法 const [count, setCount] = useState(0); const add = () => { setCount(count + 1); setCount(count + 1); setCount(count + 1); setCount(count + 1);

  // 就算執(zhí)行多次 其實還是會只執(zhí)行一次

  //class組件是用一樣的 }; 修改后 const add = () => { setCount(count => count + 1);

  //這種回調(diào)函數(shù)的寫法 setCount(count => count + 1); setCount(count => count + 1); setCount(count => count + 1);

  // class組件 this.setState(prev=>({count: prev.count})) };

在使用Hooks的過程中

  2 由于useState的是異步的,不要在修改后直接使用數(shù)據(jù)。

  可以先修改數(shù)據(jù),判斷數(shù)據(jù),也可以利用useEffec,useMemo等等通過監(jiān)聽數(shù)據(jù)執(zhí)行 const [count, setCount] = useState(0); const add = () => { setCount(count + 1); if(count>=10) { // 一個邏輯這樣的寫的話會執(zhí)行上一次吃結(jié)果} }; 正確使用

  1 const add = () => { let n = count +1 if(n){ //邏輯 } setCount(n) }; 正確

  2 : const add = () => [ setCount(count+1) ] useEffect(()=>{ // 這里是邏輯 },[count])

  3 useEffect hook的使用

  useEffect 這個hook的使用,每一個消耗性能的內(nèi)容都可以通過return 來消除 useEffect(()=>{ // 邏輯1 return ()=>{ // 清楚邏輯1的副作用 } },[監(jiān)聽的值])

  4 如果子組件是函數(shù)組件需要利用useImperativeHandle ,forWard

  useRef 可以獲取組件的數(shù)據(jù),也可當(dāng)常量的值來使用,注意獲取數(shù)據(jù)使用的時候函數(shù)組件特別需要注意,如果子組件是函數(shù)組件需要利用useImperativeHandle ,forWard

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
快速通道