zoukankan      html  css  js  c++  java
  • [React + Mobx] Mobx and React intro: syncing the UI with the app state using observable and observer

    Applications are driven by state. Many things, like the user interface, should always be consistent with that state.
    MobX is a general purpose FRP library that provides the means to derive, for example, a React based user interface automatically from the state and keep it synchronized.

    The net result of this approach is that writing applications becomes really straight-forward and boilerplate free.

    To synchronize the rendering of the state, we are going to use two functions from MobX. The first one is observable. We use observable to decorate our state to count attributes. We say, "MobX, please track this value, so that you can update observers whenever needed."

    Next, we mark our component with the observer decorator from the MobX React package. It simply tells MobX, "This component's rendering can be derived from the relevant observables. Do so whenever needed."

    const {observable} = mobx;
    const {observer} = mobxReact;
    const {Component} = React;
    
    @observer class Counter extends Component{
      @observable count = 0;
    
      render(){
        return(
          <div>
            Counter: {this.count} <br/>
            <button onClick={this.inc}>+</button>
            <button onClick={this.dec}>-</button>
          </div>
        )
      }
      
      inc = () => {
        this.count++;
      }
    
      dec = () => {
        this.count--;
      }
    }
    
    ReactDOM.render(
      <Counter />,
      document.getElementById('app')
    )

    Also spreate the state with the component will also works:

    const {observable} = mobx;
    const {observer} = mobxReact;
    const {Component} = React;
    
    const appState = observable({
       count : 0
    });
    appState.inc = function(){
      this.count++;
    }
    appState.dec = function(){
       this.count--;
    }
    
    @observer class Counter extends Component{
      render(){
        return(
          <div>
            Counter: {this.props.store.count} <br/>
            <button onClick={this.inc}>+</button>
            <button onClick={this.dec}>-</button>
          </div>
        )
      }
      
      inc = () => {
        this.props.store.inc();
      }
    
      dec = () => {
        this.props.store.dec();
      }
    }
    
    ReactDOM.render(
      <Counter store={appState}/>,
      document.getElementById('app')
    )
  • 相关阅读:
    django_开发报错
    SpringBoot 前后端数据参数交互
    消息队列学习笔记(一)
    2021年调用工商二维码退款查询接口
    2021年调用工商二维码退款接口
    2021年调用工商二维码生成接口及回调接口demo
    调用工商生成二维码接口文档的坑
    使用hutool工具类转换时间
    微信模板消息推送
    pom文件 spring-boot-maven-plugin 爆红
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5548285.html
Copyright © 2011-2022 走看看