美文网首页
react高阶组件

react高阶组件

作者: dream_Q | 来源:发表于2020-02-21 15:13 被阅读0次

一、普通组件和高阶组件的区别

一个复杂的应用由多个页面组成,一个页面由多个组件组成,组件的作用主要是界面的分治和可复用。

但在React组件的构建过程中,常常有这样的场景,有一类功能需要被不同的组件公用,此时,就涉及抽象的话题,这个时候就需要用到高阶组件。

二、高阶组件介绍

高阶组件(HOC)是 React 中用于重用组件逻辑的高级技术。 HOC 本身不是 React API 的一部分。 它们是从 React 构思本质中浮现出来的一种模式。

具体来说,高阶组件是一个函数,能够接受一个组件并返回一个新的组件。在我们项目中使用react-redux框架的时候,有一个connect的概念,这里的connect其实就是一个高阶组件。

1.实现高阶组件的方法

1.1属性代理,高阶组件通过被包裹的React组件来操作props;

1.2反向继承,高阶组件继承于被包裹的React组件。

2.属性代理

页面引用部分:

import React, { Component } from 'react';

import FormWrapper from './FormWrapper';

class Index extends Component{

    render() {

        return(

          <div>Usual</div>

        )

    }

}

export default FormWrapper(Index);

HOC部分:
import React, { Component } from 'react';

const FormWrapper = WrappedComponent =>{

  return class extends Component{ 

    render() {

      return(<WrappedComponent {...this.props} />)

      } 

  }

}

export default FormWrapper;

属性代理是我们react中常见高阶组件的实现方法,这里最重要部分是render方法中返回了传入 WrappedComponent的React组件。这样我们就可以通过高阶组件来传递props。这种方法即为属性代理。

当使用属性代理构建高阶组件时,生命周期的过程为:

didmount ->HOC didmount ->(HOCs didmount)->(HOCs will unmount)->HOC will unmount -> unmount

3.反向继承

跟属性代理的方式不同的是,反向继承采用通过去继承WrappedComponent,本来是一种嵌套的关系,结果反向继承返回的组件却继承了WrappedComponent,这看起来是一种反转的关系。通过继承WrappedComponent,除了一些静态方法,包括生命周期,state,各种function,我们都可以得到。

const FormWrapper = (WrappedComponent)=>{

  class extends WrappedComponent {

      render(){

          return super.render();

      }

  }

}

这种方法与属性代理不太一样。它通过继承WrappedComponent来实现,方法可以通过super来顺序调用。因为依赖于继承机制。HOC的调用顺序和队列是一样的。

didmount -> HOC didmount ->(HOCs didmount) -> will unmount ->HOC will unmount ->(HOCs will unmount)

4.装饰器模式

高阶组件可以看做是装饰器模式(Decorator Pattern)在React的实现。即允许向一个现有的对象添加新的功能,同时又不改变其结构,属于包装模式(Wrapper Pattern)的一种。

上面的例子还可改写为:

import React, { Component } from 'react';

import FormWrapper from './FormWrapper';

@FormWrapper;

...

三、应用场景

假设现有两个页面UI几乎一样,功能几乎相同,仅仅几个操作不太一样,却写了两个耦合很多的页面级组件。在维护它的时候,由于耦合性过多,经常在页面一改完,还要去改页面二。这时在加新功能的时候,可以写一个高阶组件,往HOC里添加方法。这样新代码就不会再出现耦合,旧的逻辑并不会改变。

相关文章

  • 利用 React 高阶组件实现一个面包屑导航

    什么是 React 高阶组件 React 高阶组件就是以高阶函数的方式包裹需要修饰的 React 组件,并返回处理...

  • React 进阶之高阶组件

    高阶组件 HOC 高阶组件(HOC)是react中的高级技术,用来重用组件逻辑。但高阶组件本身并不是React A...

  • 高阶组件

    React 高阶组件HOC (Higher-Order Component) 高阶组件是react中重复使用组件逻...

  • React高阶组件

    1、React高阶组件

  • React高阶组件HOC

    高阶组件本质是函数,参数是 组件1 返回组件2,高阶组件是为了复用通用逻辑高阶组件eg:import React,...

  • React高阶组件(HOC)

    高阶组件(Higher-Order Components) 高阶组件(HOC)是 React 中用于重用组件逻辑的...

  • react 笔记

    react 基本概念解析 react 的组件声明周期 react 高阶组件,context, redux 等高级...

  • ReactNative中的高阶组件(HOC)和继承详解

    ReactNative中的高阶组件(HOC)和继承详解 共同点: 高阶组件(HOC)是 React 中用于复用组件...

  • React高阶组件

    React高阶组件 在开始聊高阶组件之前我们先来看下高阶函数和高阶组件在形式上的差异: 一、什么是装饰器模式: 要...

  • React 高阶组件

    当 React 组件被包裹时(wrapped),高阶组件会返回一个增强(enhanced)的 React 组件。高...

网友评论

      本文标题:react高阶组件

      本文链接:https://www.haomeiwen.com/subject/cimcqhtx.html