码迷,mamicode.com
首页 > 其他好文 > 详细

react-native+MobX

时间:2019-01-07 21:05:46      阅读:212      评论:0      收藏:0      [点我收藏+]

标签:函数   index   版本   on()   navigator   page   efault   const   route   

参考https://segmentfault.com/a/1190000014165693同事解决其发生的问题
1.版本
"mobx": "4.3.1",
"mobx-react": "5.1.0",
否则会报错


2.安装
yarn add babel-plugin-transform-decorators-legacy
yarn add babel-preset-react-native-stage-0
yarn add babel-plugin-transform-runtime

3.创建store文件夹,并在下面创建几个js文件
// home
import { observable, action } from "mobx";

class HomeStore {
  @observable text; // 注册变量,使其成为可检测的
  @observable num;

  constructor() {
    this.num = 0; // 初始化变量,可以定义默认值
    this.text = "Hello, this is homePage!!!";
  }

  @action  // 方法推荐用箭头函数的形式
  plus = () => {
    this.num += 1;
  };

  @action
  minus = () => {
    this.num -= 1;
  };
}

const homeStore = new HomeStore(); 

export { homeStore };


// user
import { observable, action } from "mobx";

class UserStore {
  @observable userInfo;
  @observable text;

  constructor() {
    this.userInfo = "123";
    this.text = "Hello, this is UserPage!!!";
  }

  @action
  getListData = () => {
    fetch(`http://yapi.demo.qunar.com/mock/5228/record/list`)
      .then(
        action("fetchRes", res => {
          return res.json();
        })
      )
      .then(
        action("fetchSuccess", data => {
          return (this.userInfo = data);
        })
      )
      .catch(
        action("fetchError", e => {
          console.log(e.message);
        })
      );
  };
}
4.在store文件夹下创建一个index.js文件将刚刚创建的两个js文件引入到里面
import { homeStore } from "./home";
import { userStore } from "./user";
const store = { homeStore,userStore};

export default store;

5.在App.js中将其引入
import React,{Component} from ‘react‘;
import {Provider} from ‘mobx-react‘;
import AppStackNavigator from "./Router";
import store from ‘./store‘;
export default class App extends Component{
render(){
return (
<Provider {...store}>
<AppStackNavigator></AppStackNavigator>
</Provider>
)
}
}

6.调用状态机
import {observer,inject} from ‘mobx-react‘;
@inject(‘homeStore‘) @observer;
<Text>状态管理器</Text>
<Text>{this.props.homeStore.name}</Text>
<Text>{this.props.homeStore.msg}</Text>

 

react-native+MobX

标签:函数   index   版本   on()   navigator   page   efault   const   route   

原文地址:https://www.cnblogs.com/boonook/p/10234440.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!