亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

React子組件調(diào)用父組件方法獲取的數(shù)據(jù)不是最新值的解決方法

 更新時(shí)間:2024年09月06日 09:22:31   作者:一條大河全靠浪  
這篇文章主要介紹了React子組件調(diào)用父組件方法獲取的數(shù)據(jù)不是最新值的解決方法,文中通過(guò)代碼示例介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下

出現(xiàn)問(wèn)題的代碼如下:

const Parent: React.FC = () => {
  const [val, setVal] = useState(0);

  const onBtnsClick = () => {
    console.log(val);
  };

  return (
    <div>
      {val}
      <button onClick={() => setVal(val => val + 1)}>加一</button>
      <Child onClick={onBtnsClick} />
    </div>
  );
};

const Child: React.FC<{ onClick: () => void }> = ({ onClick }) => {
  // useCallback + 防抖
  const onBtnClick = useCallback(
    _.debounce(onClick, 1000, { leading: true, trailing: false }),
    []
  );
  return <button onClick={onBtnClick}>子組件</button>;
};

原因

父組件狀態(tài)的變更沒(méi)有引起該子組件中的onBtnClick重新生成,導(dǎo)致方法中的 val 為一開(kāi)始傳入的數(shù)值0

解決方法

想辦法觸發(fā)組件刷新,使onBtnsClick 中打印的 val 永遠(yuǎn)是最新的值

方法一、去掉 useCallback, 這樣每次父組件觸發(fā)刷新,就會(huì)刷新子組件

// 如果點(diǎn)擊的事件不會(huì)導(dǎo)致父組件刷新,從而刷新子組件
const onBtnClick = _.debounce(onClick, 1000, {
  leading: true,
  trailing: false,
});

但這種方式只適用于一種情況:點(diǎn)擊事件的處理不會(huì)導(dǎo)致父組件刷新;
如果父組件刷新,就會(huì)導(dǎo)致子組件刷新,從而 debounce 又新建,導(dǎo)致防抖無(wú)效。

如果想父組件刷新,子組件不刷新,可以父組件函數(shù)onBtnsClick用useCallback包裹,Child組件用memo包裹

完整代碼如下:

const Test: React.FC = () => {
  const [val, setVal] = useState(0);
  const onBtnsClick = useCallback(() => {
    console.log(val);
    setVal(val => val + 2)
  }, [val]);

  return (
    <div>
      {val}
      <button onClick={() => setVal(val => val + 1)}>加一</button>
      <div>
       <Child onClick={onBtnsClick} />
  );
};

const Child = memo(({ onClick }) => {
  const onBtnClick = _.debounce(onClick, 1000, {
    leading: true,
    trailing: false,
  });
  return <button onClick={onBtnClick}>子組件</button>;
});

方法二、或者通過(guò)監(jiān)聽(tīng) val,val 值改變來(lái)刷新函數(shù)

const onBtnClick2 = useCallback(
  _.debounce(onClick, 1000, { leading: true, trailing: false }),
  [val]
);

方法三、在父組件中,把 val 作為 key 值,每次 val 變化強(qiáng)制觸發(fā)更新

這個(gè)改動(dòng)是最小的

<Child key={val} onClick={onBtnsClick} />

// 或者
<div key={val}>
  <Child  onClick={onBtnsClick} />
</div>

到此這篇關(guān)于React子組件調(diào)用父組件方法獲取的數(shù)據(jù)不是最新值的解決方法的文章就介紹到這了,更多相關(guān)React子組件調(diào)用父組件獲取數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 基于react組件之間的參數(shù)傳遞(詳解)

    基于react組件之間的參數(shù)傳遞(詳解)

    下面小編就為大家?guī)?lái)一篇基于react組件之間的參數(shù)傳遞(詳解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • react echarts刷新不顯示問(wèn)題的解決方法

    react echarts刷新不顯示問(wèn)題的解決方法

    最近在寫(xiě)項(xiàng)目的時(shí)候遇到了一個(gè)問(wèn)題,當(dāng)編輯完代碼后echarts圖正常展示 , 可再次刷新頁(yè)面 , echarts會(huì)消失,所以本文給大家介紹了react echarts刷新不顯示問(wèn)題原因和解決方法,需要的朋友可以參考下
    2024-02-02
  • react?表單數(shù)據(jù)形式配置化設(shè)計(jì)

    react?表單數(shù)據(jù)形式配置化設(shè)計(jì)

    這篇文章主要介紹了react表單數(shù)據(jù)形式配置化設(shè)計(jì),文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的朋友可以參考一下
    2022-07-07
  • React Hooks常用鉤子及基本原理解讀

    React Hooks常用鉤子及基本原理解讀

    這篇文章主要介紹了React Hooks常用鉤子及基本原理,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • VSCode 配置React Native開(kāi)發(fā)環(huán)境的方法

    VSCode 配置React Native開(kāi)發(fā)環(huán)境的方法

    本篇文章主要介紹了VSCode 配置React Native開(kāi)發(fā)環(huán)境的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • React里的Fragment標(biāo)簽的具體使用

    React里的Fragment標(biāo)簽的具體使用

    本文主要介紹了React里的Fragment標(biāo)簽的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • React Native 真機(jī)斷點(diǎn)調(diào)試+跨域資源加載出錯(cuò)問(wèn)題的解決方法

    React Native 真機(jī)斷點(diǎn)調(diào)試+跨域資源加載出錯(cuò)問(wèn)題的解決方法

    下面小編就為大家分享一篇React Native 真機(jī)斷點(diǎn)調(diào)試+跨域資源加載出錯(cuò)問(wèn)題的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-01-01
  • React數(shù)據(jù)傳遞之組件內(nèi)部通信的方法

    React數(shù)據(jù)傳遞之組件內(nèi)部通信的方法

    這篇文章主要介紹了React數(shù)據(jù)傳遞之組件內(nèi)部通信的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • 關(guān)于react-router/react-router-dom v4 history不能訪問(wèn)問(wèn)題的解決

    關(guān)于react-router/react-router-dom v4 history不能訪問(wèn)問(wèn)題的解決

    這篇文章主要給大家介紹了關(guān)于react-router/react-router-dom v4 history不能訪問(wèn)問(wèn)題的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • React項(xiàng)目開(kāi)發(fā)中函數(shù)組件與函數(shù)式編程關(guān)系

    React項(xiàng)目開(kāi)發(fā)中函數(shù)組件與函數(shù)式編程關(guān)系

    函數(shù)組件和函數(shù)式編程究竟是什么關(guān)系呢?本文會(huì)圍繞這個(gè)話題展開(kāi)講解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-11-11

最新評(píng)論