react高阶组件

前端 0 307 0
发表于: 2020-10-14 21:19:07

简介: 暂无~

高阶组件

高阶组件的英文是 Higher-Order Components,简称为 HOC;
官方的定义:高阶组件是参数为组件,返回值为新组件的函数;
我们可以进行如下的解析: p 首先, 高阶组件 本身不是一个组件,而是一个函数;
其次,这个函数的参数是一个组件,返回值也是一个组件;

定义

import React, { PureComponent } from 'react'

class App extends PureComponent {
  render() {
    console.log(this.props);
    return (
      <div>
        App: {this.props.name}
      </div>
    )
  }
}

// 类组件
// function enhanceComponent(WrappedComponent) {
//   class NewComponent extends PureComponent {
//     render() {
//       // return <WrappedComponent name={this.props.name} />
//       return <WrappedComponent {...this.props} />
//     }
//   }

//   NewComponent.displayName = "Kobe";
//   return NewComponent;
// }

// 函数组件
function enhanceComponent(WrappedComponent) {
  function NewComponent(props) {
    return <WrappedComponent {...props}/>
  }

  NewComponent.displayName = "Kobe";
  return NewComponent;
}

const EnhanceComponent = enhanceComponent(App);

export default EnhanceComponent;

应用1-增强props

import React, { PureComponent } from 'react';

// 定义一个高阶组件
function enhanceRegionProps(WrappedComponent) {
  return function aaa(props){
    return <WrappedComponent {...props} region="中国"/>
  }
  // return props => {
  //   return <WrappedComponent {...props} region="中国"/>
  // }

  /*  为什么props有值
      因为调用enhanceRegionProps高阶组件(本质还是函数),
      会返回一个函数(也可以说是函数组件),
      然后const EnhanceHome = enhanceRegionProps(Home),
      调用了enhanceRegionProps高阶组件(函数),
      返回了一个aaa函数(函数组件)给EnhanceHome,
      等于EnhanceHome就aaa函数(函数组件),
      然后<EnhanceHome nickname="coderwhy" level={90}/>
      这里EnhanceHome就是函数组件了,
      因此nickname和level都可以通过aaa函数的形参props获取
  */
}

class Home extends PureComponent {
  render() {
    return <h2>Home: {`昵称: ${this.props.nickname} 等级: ${this.props.level} 区域: ${this.props.region}`}</h2>
  }
}


class About extends PureComponent {
  render() {
    return <h2>About: {`昵称: ${this.props.nickname} 等级: ${this.props.level} 区域: ${this.props.region}`}</h2>
  }
}


/*
  一般情况下是默认导出Home组件,然后其他地方import Home from ''
  别人以为导入的是Home,其实导入的是这里导出的enhanceRegionProps(Home)
  然后就可以在其他地方直接使用<Home />和<About />
  export default enhanceRegionProps(Home);
  export default enhanceRegionProps(About);
*/

// 这里因为没有导出,想用enhanceRegionProps(Home)就得这样
const EnhanceHome = enhanceRegionProps(Home);
const EnhanceAbout = enhanceRegionProps(About);

class App extends PureComponent {
  render() {
    return (
      <div>
        App
        <EnhanceHome nickname="coderwhy" level={90}/>
        <EnhanceAbout nickname="kobe" level={99}/>
      </div>
    )
  }
}

export default App;

import React, { PureComponent } from 'react';

// 定义一个高阶组件
function enhanceRegionProps(WrappedComponent) {
  return function aaa(props){
    return <WrappedComponent {...props} region="中国"/>
  }
  // return props => {
  //   return <WrappedComponent {...props} region="中国"/>
  // }

  /*  为什么props有值
      因为调用enhanceRegionProps高阶组件(本质还是函数),
      会返回一个函数(也可以说是函数组件),
      然后const EnhanceHome = enhanceRegionProps(Home),
      调用了enhanceRegionProps高阶组件(函数),
      返回了一个aaa函数(函数组件)给EnhanceHome,
      等于EnhanceHome就aaa函数(函数组件),
      然后<EnhanceHome nickname="coderwhy" level={90}/>
      这里EnhanceHome就是函数组件了,
      因此nickname和level都可以通过aaa函数的形参props获取
  */
}

class Home extends PureComponent {
  render() {
    return <h2>Home: {`昵称: ${this.props.nickname} 等级: ${this.props.level} 区域: ${this.props.region}`}</h2>
  }
}


class About extends PureComponent {
  render() {
    return <h2>About: {`昵称: ${this.props.nickname} 等级: ${this.props.level} 区域: ${this.props.region}`}</h2>
  }
}


/*
  一般情况下是默认导出Home组件,然后其他地方import Home from ''
  别人以为导入的是Home,其实导入的是这里导出的enhanceRegionProps(Home)
  然后就可以在其他地方直接使用<Home />和<About />
  export default enhanceRegionProps(Home);
  export default enhanceRegionProps(About);
*/

// 这里因为没有导出,想用enhanceRegionProps(Home)就得这样
const EnhanceHome = enhanceRegionProps(Home);
const EnhanceAbout = enhanceRegionProps(About);

class App extends PureComponent {
  render() {
    return (
      <div>
        App
        <EnhanceHome nickname="coderwhy" level={90}/>
        <EnhanceAbout nickname="kobe" level={99}/>
      </div>
    )
  }
}

export default App;

应用2-增强props-Context-默认

import React, { PureComponent, createContext } from 'react';

// 创建Context
const UserContext = createContext({
  nickname: "默认",
  level: -1,
  region: "世界"
});

class Home extends PureComponent {
  render() {
    return (
      <UserContext.Consumer>
        {
          user => {
            return <h2>Home: {`昵称: ${user.nickname} 等级: ${user.level} 区域: ${user.region}`}</h2>
          }
        }
      </UserContext.Consumer>
    )
  }
}

class About extends PureComponent {
  render() {
    return (
      <UserContext.Consumer>
        {
          user => {
            return <h2>About: {`昵称: ${user.nickname} 等级: ${user.level} 区域: ${user.region}`}</h2>
          }
        }
      </UserContext.Consumer>
    )
  }
}

class App extends PureComponent {
  render() {
    return (
      <div>
        App
        <UserContext.Provider value={{ nickname: "why", level: 90, region: "中国" }}>
          <Home />
          <About />
        </UserContext.Provider>
      </div>
    )
  }
}

export default App;

应用3-增强props-Context-改进

import React, { PureComponent, createContext } from 'react';

// 定义一个高阶组件
function withUser(WrappedComponent) {
  // 返回一个函数组件
  return props => {
    // 返回jsx
    return (
      <UserContext.Consumer>
        {
          user => {
            // 给WrappedComponent传props值(如:<UserHome pwd={123456}/>的pwd)
            // 以及context的value值(这里起user别名),<UserContext.Provider value...>
            // 然后WrappedComponent组件(即withUser这个高阶组件的形参)就能拥有props的值和context的值了
            // 约等于父子组件传值,父组件将{...props} {...user}数据传给WrappedComponent子组件

            // return <WrappedComponent 
            //           nickname={user.nickname}
            //           level={user.level}
            //           region={user.region}
            //           pwd={props.pwd}
            //           hobby={props.hobby}
            //         />
            return <WrappedComponent {...props} {...user}/>
          } 
        }
      </UserContext.Consumer>
    )
  }
}

// 创建Context
const UserContext = createContext({
  nickname: "默认",
  level: -1,
  region: "世界"
});

class Home extends PureComponent {
  render() {
    return <h2>Home: {`昵称: ${this.props.nickname} 密码: ${this.props.pwd} 等级: ${this.props.level} 区域: ${this.props.region}`}</h2>
  }
}


class About extends PureComponent {
  render() {
    return <h2>About: {`昵称: ${this.props.nickname} 密码: ${this.props.hobby} 等级: ${this.props.level} 区域: ${this.props.region}`}</h2>
  }
}

class Detail extends PureComponent {
  render() {
    return (
      <ul>
        <li>{this.props.nickname}</li>
        <li>{this.props.level}</li>
        <li>{this.props.region}</li>
      </ul>
    )
  }
}


const UserHome = withUser(Home);
const UserAbout = withUser(About);
const UserDetail = withUser(Detail);

class App extends PureComponent {
  render() {
    return (
      <div>
        App
        <UserContext.Provider value={{nickname: "why", level: 90, region: "中国"}}>
          <UserHome pwd={123456}/>
          <UserAbout hobby={'coding'}/>
          <UserDetail/>
        </UserContext.Provider>
      </div>
    )
  }
}

export default App;

应用3-登录鉴权


React

最后更新于:2021-02-16 21:16:31

欢迎评论留言~
0/400
支持markdown
Comments | 0 条留言
按时间
按热度
目前还没有人留言~