JS異步解決父子組件傳值問題

業(yè)務(wù)場景:在父組件加載頁面的時候,獲取子組件中通過網(wǎng)絡(luò)請求獲取的值,
用到的hook:useEffect()、useRef()。

這里是父組件

const BaseAssestsTreeContext = createContext(); 
const myRefAssetMonitor=useRef()

//父組件關(guān)鍵useEffect
  useEffect(() => {
    console.log("====父頁面,useEffect方法")
    console.log("===進來父頁面去獲取 getD()",myRefAssetMonitor.current.getD())
    setTimeout(()=>{
      if(groupId){
        queryAreaAsset(groupId);
      }else{
        console.log("===延時去獲取 子頁面的鉤子方法 myRefAssetMonitor.current.getD()",myRefAssetMonitor.current)
        queryAreaAsset(myRefAssetMonitor.current.getD());
        setGroupId(myRefAssetMonitor.current.getD())
      }
    },300)
  }, [])
 <div className={style.bg}>
        <div className={style.bg_tree}>
          <BaseAssestsTreeContext.Provider>
            <BaseAssestsTree myContext={BaseAssestsTreeContext} myRef={myRefAssetMonitor}/>
          </BaseAssestsTreeContext.Provider>
        </div>
        <div />

這里是子組件

  useEffect(() => {
    console.log("====子頁面  資產(chǎn)樹 useEffect方法")
    tree();//這里獲取網(wǎng)絡(luò)請求
  }, []);

  //想暴露給父組件的值 
  useImperativeHandle(myRef, () => ({
    getD: () => {
      return defaultGroupId;
    }
  }));
父子組件渲染順序和鉤子函數(shù)值.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容