我已成功连接我的组件Details.js
以便管理组件本身的状态,这些是步骤:
你可以在这里看到演示
细节.js
import 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} />;
});
应用程序.js
const ref = useRef();
<button onClick={() => ref.current.cleanValue()} type="button">Reset</button>
<Details ref={ref} />
它有效,演示在这里。
我的问题是当我将此元素从App.js移动到Leagues.js时,您可以在演示中看到(两种情况)
联赛.js
71号线
<button onClick={() => ref.current.cleanValue()} type="button">Reset</button>
当我点击它时出现此错误 => TypeError Cannot read property 'cleanValue' of undefined
是否可以 ?如果是,我做错了什么,我该如何解决?
largeQ
相关分类