什么是高阶组件

  1. 高阶组件(HOC)是一个将组件作为参数并返回一个新组件的函数。他是一种由 React 自身组合性质产生的模式。由于高阶组件接受他的组件参数来动态创建子组件,且不会修改或复制其组件中的任何行为,因此他与纯组件较为类似。

    1. 高阶组件可以用来作为状态的抽象和管理、属性的管理、组件的渲染等。

      由于 Mixins 产生的问题比其带来的价值要大的多,因此我们要么避免过早的抽象,要么可以使用高阶组件。

      不要在 render 方法内使用高阶组件,否则每一次渲染都会创建一个新的组件,并引起该组件的卸载和渲染。

      高阶组件返回的新组件中将没有参数组件中的任何静态方法。因此需要对静态方法进行拷贝(可使用 hoist-non-react-statics )或分别导出组件自身的静态方法。

      在高阶组件中由于 refs 属性不能贯穿传递,但可以使用 React.forwardRef 来替代。

      在高阶组件内,应避免对组件做任何修改。应使用组合技术,将输入的组件包裹到一个容器组件中。

你可能感兴趣的:(react.js,javascript,前端)