【发布时间】:2019-12-15 00:01:15
【问题描述】:
高阶组件不适用于功能组件。
我正在尝试创建一个示例功能 HOC。我正在使用反应钩子 useState 并将状态传递给传递的组件。下面是我的代码
function HOC(WrapperComponent) {
// outside of return function
const [course] = useState({ id: 0, name: "Raja/Kondla" });
return function() {
return <WrapperComponent course={course} />;
};
}
const Comp = HOC(({ course }) => {
return (
<>
<div>HOC</div>
<div>{course.id}</div>
<div>{course.name}</div>
<div>-------------------</div>
</>
);
});
ReactDOM.render(<Comp />, rootElement);
当我运行它时,我遇到了错误。
无效的挂钩调用。钩子只能在函数组件的主体内部调用。这可能是由于以下原因之一:
- 您的 React 和渲染器版本可能不匹配(例如 React DOM)
- 您可能违反了 Hooks 规则
- 您可能在同一个应用程序中拥有多个 React 副本
但是如果我把下面的代码作为 HOC 工作正常。
function HOC(WrapperComponent) {
return function() {
// inside return function
const [course] = useState({ id: 0, name: "Raja/Kondla" });
return <WrapperComponent course={course} />;
};
}
得到结果输出:
HOC
0
Raja/Kondla
谁能解释一下是什么原因?并且使用函数式 HOC,会不会对性能产生影响?
提前致谢
【问题讨论】:
-
´HOC(({ course })´ 你的意思是写 ´HOC((course)´ 吗?
标签: javascript reactjs react-hooks