亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

反應元素位置的 UseRef 和 forwardRef 問題

反應元素位置的 UseRef 和 forwardRef 問題

慕雪6442864 2023-03-18 16:11:18
我已成功連接我的組件Details.js以便管理組件本身的狀態,這些是步驟:你可以在這里看到演示細節.jsimport React, { useState, useEffect, useRef, ref, useImperativeHandle, forwardRef } from "react";  const cleanValue = () => {    setDataHomeTeam([]);    setDataAwayTeam([]);  };  useImperativeHandle(fowardedRef, () => {    return {      cleanValue: cleanValue    };  });const ConnectedDetails = connect(  mapStateToProps,  mapDispatchToProps,  null)(Details);export default forwardRef((props, ref) => {  return <ConnectedDetails {...props} fowardedRef={ref} />;});應用程序.jsconst ref = useRef();  <button onClick={() => ref.current.cleanValue()} type="button">Reset</button><Details ref={ref} />它有效,演示在這里。我的問題是當我將此元素從App.js移動到Leagues.js時,您可以在演示中看到(兩種情況)聯賽.js71號線<button onClick={() => ref.current.cleanValue()} type="button">Reset</button>當我點擊它時出現此錯誤 => TypeError Cannot read property 'cleanValue' of undefined是否可以 ?如果是,我做錯了什么,我該如何解決?
查看完整描述

1 回答

?
largeQ

TA貢獻2039條經驗 獲得超8個贊

正如評論中所指出的,主要問題是組件ref內的引用Leagues未指向Details組件。

可以對原始代碼進行以下 3 處修改,以使組件中的按鈕正常Leagues工作:

  1. onResetLeagues組件添加屬性

     let Leagues = ({
           getList,
           getStats,
           leaguesList,
           loading,
           getDetail,
           teamsDetail,
           onReset
         })
  2. 使用組件onReset中的函數Leagues

    原文: <button onClick={() => ref.current.cleanValue()} type="button">

    新的: <button onClick={onReset} type="button">

  3. onReset將組件的屬性設置為將調用組件方法的Leagues函數cleanValue()Details

    原來的: <Leagues />

    新的: <Leagues onReset={() => ref.current.cleanValue()} />

完整的代碼可以在這里找到。

請注意,從架構的角度來看,不建議組件通過引用訪問其兄弟組件。許多似乎需要這樣做的場景可能通過父組件更好地處理。


查看完整回答
反對 回復 2023-03-18
  • 1 回答
  • 0 關注
  • 97 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號