千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

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

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

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

  1 首先注意到就是 useState

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

  // 就算執行多次 其實還是會只執行一次

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

  //這種回調函數的寫法 setCount(count => count + 1); setCount(count => count + 1); setCount(count => count + 1);

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

在使用Hooks的過程中

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

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

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

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

  3 useEffect hook的使用

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

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

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

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
中文字幕在线播放 | 在线观看免费的成年影片 | 在线观看国产日韩亚洲中 | 在线亚洲中文精品第1页视频 | 日本道二区免费 | 亚洲国产精品一区二区第一页免 |