javascript - React 函数高阶组件

标签 javascript reactjs react-hooks

高阶组件不适用于功能组件。

我正在尝试创建一个示例功能 HOC。我正在使用 React hook 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);

当我运行它时,出现以下错误。

无效的 Hook 调用。钩子(Hook)只能在函数组件的主体内部调用。发生这种情况可能是由于以下原因之一:

  1. 您的 React 和渲染器版本可能不匹配(例如 React DOM)
  2. 您可能违反了 Hooks 规则
  3. 您可能在同一个应用程序中拥有多个 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 是一个返回 React 组件的函数,这就是为什么当你将该行放入返回的函数组件中时它会起作用。

话虽如此,我会重新考虑在使用钩子(Hook)时是否需要 HOC,HOC 的目的是跨组件共享逻辑,钩子(Hook)解决了相同的挑战(以更好的方式)。

很难理解您在示例中尝试与 HOC 分享的逻辑,但我会选择 custom hook instead .

来自文档:

Traditionally in React, we’ve had two popular ways to share stateful logic between components: render props and higher-order components. We will now look at how Hooks solve many of the same problems without forcing you to add more components to the tree.

关于javascript - React 函数高阶组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57392876/

相关文章:

javascript - 使用 Hooks 在 React 中更新数组

reactjs - Hook 函数中的句柄函数

reactjs - 如何使用本地存储、react hooks 和 Context Provider 保持状态持久

javascript - 使用 RxJs Observable 包装基于 Promise 的 JavaScript HTTP 客户端

javascript - 在后台加载 iframe 网站

javascript - 如何在 React 中滚动时切换图像(就像在 Apple 网站上一样)?

reactjs - React Prop 类型根据标志不同所需的 Props

javascript - 对箭头函数感到困惑

javascript - 无法使用 JavaScript/jQuery 打开新选项卡或窗口

javascript - 为什么我的 React useState 异步更新我的上下文?