zoukankan      html  css  js  c++  java
  • [React] Higher Order Components (replaces Mixins)

    Higher order components will allow you to apply behaviors to multiple React components.

    So the idea is to create a high order component, then use this hight order component to create multi same behaivor component. 

    So high order function is insdie function return another function, the same, high order component is inside component return another component.

    let Mixin = InnerComponent => class extends React.Component {
      constructor(){
        super();
        this.state = {val: 0}
      }
      update(){
        this.setState({val: this.state.val + 1})
      }
      componentWillMount(){
        console.log('will mount')
      }
      render(){
        return <InnerComponent
          update={this.update.bind(this)}
          {...this.state}
          {...this.props} />
      }
      componentDidMount(){
        console.log('mounted')
      }
    }

    Inside the Mixin Component, we define the behavior "update" which will be shared to the mixined components.

    Define two component: 

    const Button = (props) => <button
                                onClick={props.update}>
                                {props.txt} - {props.val}
                              </button>
    
    const Label = (props) => <label
                                onMouseMove={props.update}>
                                {props.txt} - {props.val}
                              </label>

    Mixin those two component with Mixin:

    let ButtonMixed = Mixin(Button)
    let LabelMixed = Mixin(Label)

    Use it:

    class App extends React.Component {
    
      render(){
        return (
          <div>
            <ButtonMixed txt="Button" />
            <LabelMixed txt="Label" />
          </div>
        );
      }
    
    }
    
    ReactDOM.render(<App />, document.getElementById('app'));

    ----- 

    let Mixin = InnerComponent => class extends React.Component {
      constructor(){
        super();
        this.state = {val: 0}
      }
      update(){
        this.setState({val: this.state.val + 1})
      }
      componentWillMount(){
        console.log('will mount')
      }
      render(){
        return <InnerComponent
          update={this.update.bind(this)}
          {...this.state}
          {...this.props} />
      }
      componentDidMount(){
        console.log('mounted')
      }
    }
    
    
    const Button = (props) => <button
                                onClick={props.update}>
                                {props.txt} - {props.val}
                              </button>
    
    const Label = (props) => <label
                                onMouseMove={props.update}>
                                {props.txt} - {props.val}
                              </label>
    
    let ButtonMixed = Mixin(Button)
    let LabelMixed = Mixin(Label)
    
    class App extends React.Component {
    
      render(){
        return (
          <div>
            <ButtonMixed txt="Button" />
            <LabelMixed txt="Label" />
          </div>
        );
      }
    
    }
    
    ReactDOM.render(<App />, document.getElementById('app'));
  • 相关阅读:
    spring 自定义事件发布及监听(简单实例)
    解析spring中的BeanFactory(看完会有收获)
    如何提高锁的性能
    spring MVC模式拦截所有入口方法的入参出参打印
    java基于feemarker 生成word文档(超级简单)
    数据库事务特性汇总
    如何让window.open()以post请求方式调用(巧妙解法)
    a标签添加背景图片的解决办法
    深入理解Django Admin的list_display, list_filter和raw_id_fields,filter_horizontal选项
    django配置log日志
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5746248.html
Copyright © 2011-2022 走看看