欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React useCallback使用教程

 更新時間:2023年01月05日 10:53:29   作者:折桂懷橘  
useCallback是react中比較重要的一個hook,useCallback 用來返回一個函數(shù),在父子組件傳參或者通用函數(shù)封裝中,起到舉足輕重的作用

開始之前請注意這句話:任何優(yōu)化都會增加復雜性,任何過早添加的優(yōu)化都會帶來風險,因為優(yōu)化后的代碼可能會多次更改

useEffect

相關作用:監(jiān)聽 & 初始化

//最簡單用法
   useEffect(() => {
     //只有方法體,相當于componentDidMount和componentDidUpdate中的代碼
    document.title = count;
  })
  //加返回值用法
  useEffect(() => {
    //添加監(jiān)聽事件,相當于componentDidMount和componentDidUpdate中的代碼
    window.addEventListener('resize', onChange, false);
    //返回的函數(shù)用于解綁事件,相當于componentWillUnmount中的代碼
    return () => {
      window.removeEventListener('resize', onChange, false)
    }
  })
  //加空數(shù)組參數(shù)用法
  useEffect(() => {
    // 相當于 componentDidMount
    window.addEventListener('resize', onChange, false)
    return () => {
      // 相當于 componentWillUnmount
      window.removeEventListener('resize', onChange, false)
    }
  }, []);
  //加監(jiān)聽值用法
  useEffect(() => {
   //只有當count的值發(fā)生變化,此函數(shù)才會執(zhí)行
    console.log(`count change: count is ${count}`)
  }, [ count ]);

useCallback

先看一個最簡單的例子:

// 用于記錄 getData 調用次數(shù)
let count = 0;
function App() {
  const [val, setVal] = useState("");
  function getData() {
    setTimeout(()=>{
      setVal('new data '+count);
      count++;
    }, 500)
  }
  useEffect(()=>{
    getData();
  }, []);
  return (
    <div>{val}</div>
  );}

getData模擬發(fā)起網絡請求。在這種場景下,沒有useCallback什么事,組件本身是高內聚的。

如果涉及到組件通訊,情況就不一樣了:

// 用于記錄 getData 調用次數(shù)
let count = 0;
function App() {
  const [val, setVal] = useState("");
  function getData() {
    setTimeout(() => {
      setVal("new data " + count);
      count++;
    }, 500);
  }
  return <Child val={val} getData={getData} />;}function Child({val, getData}) {
  useEffect(() => {
    getData();
  }, [getData]);
  return <div>{val}</div>;}

就這么輕輕松松,一個死循環(huán)就誕生了…

先來分析下這段代碼的用意,Child組件是一個純展示型組件,其業(yè)務邏輯都是通過外部傳進來的,這種場景在實際開發(fā)中很常見。

再分析下代碼的執(zhí)行過程:

  • App渲染Child,將val和getData傳進去
  • Child使用useEffect獲取數(shù)據(jù)。因為對getData有依賴,于是將其加入依賴列表
  • getData執(zhí)行時,調用setVal,導致App重新渲染
  • App重新渲染時生成新的getData方法,傳給Child
  • Child發(fā)現(xiàn)getData的引用變了,又會執(zhí)行getData
  • 3 -> 5 是一個死循環(huán)

如果明確getData只會執(zhí)行一次,最簡單的方式當然是將其從依賴列表中刪除。但如果裝了 hook 的lint 插件,會提示:React Hook useEffect has a missing dependency

useEffect(() => {
  getData();}, []);

實際情況很可能是當getData改變的時候,是需要重新獲取數(shù)據(jù)的。這時就需要通過useCallback來將引用固定?。?/p>

const getData = useCallback(() => {
  setTimeout(() => {
    setVal("new data " + count);
    count++;
  }, 500);}, []);

上面例子中getData的引用永遠不會變,因為他它的依賴列表是空??梢愿鶕?jù)實際情況將依賴加進去,就能確保依賴不變的情況下,函數(shù)的引用保持不變。

還有一個要注意的是

在開始監(jiān)聽一個鼠標的移動的時候,想要刪除這個監(jiān)聽不生效,由于是, 加入useState導致組件再次渲染 handleMouse 函數(shù)在次渲染, handleMouse 作為組件內的方法, 會跟著一同再次渲染, 并且在內存里, 再次渲染出的 clickFunc !== 前clickFunc.

所以removeEventListener無法解除綁定, 再次addEventListener則會綁定一個新方法.

document.addEventListener('mousemove',handleMouse,true)

解決方案 : useCallback 緩存改方法 這時候的 document.removeEventListener(‘mousemove’,handleMouse,true) 中的handleMouse 和添加中的方法就是一個了,就能刪除了。

onst handleMouse= useCallback(() => {
//xxxx
    console.log("clicking");
  }, []);

到此這篇關于React useCallback使用教程的文章就介紹到這了,更多相關React useCallback內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • React 中引入 CSS 高階用法的方案詳解

    React 中引入 CSS 高階用法的方案詳解

    這篇文章主要介紹了React中引入CSS高階用法的方案詳解,至于使用react用哪種方案引入css,并沒有一個絕對的答案,可以根據(jù)各自情況選擇合適的方案,需要的朋友可以參考下
    2024-02-02
  • Reactjs?錯誤邊界優(yōu)雅處理方法demo

    Reactjs?錯誤邊界優(yōu)雅處理方法demo

    這篇文章主要為大家介紹了Reactjs?錯誤邊界優(yōu)雅處理方法demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • react腳手架構建運行時報錯問題及解決

    react腳手架構建運行時報錯問題及解決

    這篇文章主要介紹了react腳手架構建運行時報錯問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 詳解如何封裝和使用一個React鑒權組件

    詳解如何封裝和使用一個React鑒權組件

    JavaScript?和?React?提供了靈活的事件處理機制,特別是通過利用事件的捕獲階段來阻止事件傳播可以實現(xiàn)精細的權限控制,本文將詳細介紹這一技術的應用,并通過實踐案例展示如何封裝和使用一個?React?鑒權組件,需要的可以參考下
    2024-03-03
  • React使用redux基礎操作詳解

    React使用redux基礎操作詳解

    這篇文章主要介紹了如何在React中直接使用Redux,目前redux在react中使用是最多的,所以我們需要將之前編寫的redux代碼,融入到react當中去,本文給大家詳細講解,需要的朋友可以參考下
    2023-01-01
  • 在react-antd中彈出層form內容傳遞給父組件的操作

    在react-antd中彈出層form內容傳遞給父組件的操作

    這篇文章主要介紹了在react-antd中彈出層form內容傳遞給父組件的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • antd之RangePicker設置默認值方式

    antd之RangePicker設置默認值方式

    這篇文章主要介紹了antd之RangePicker設置默認值方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • React class和function的區(qū)別小結

    React class和function的區(qū)別小結

    Class組件和Function組件是React中創(chuàng)建組件的兩種主要方式,本文主要介紹了React class和function的區(qū)別小結,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10
  • React中遍歷數(shù)組生成標簽問題

    React中遍歷數(shù)組生成標簽問題

    這篇文章主要介紹了React中遍歷數(shù)組生成標簽問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • react如何實現(xiàn)側邊欄聯(lián)動頭部導航欄效果

    react如何實現(xiàn)側邊欄聯(lián)動頭部導航欄效果

    這篇文章主要介紹了react如何實現(xiàn)側邊欄聯(lián)動頭部導航欄效果,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-03-03

最新評論