React Native中Mobx的使用方法详解


Posted in Javascript onDecember 04, 2018

前言

从今天开始我们来搞搞状态管理可否,这几天没怎么写博客,因为被病魔战胜了,tmd,突然的降温让我不知所措,大家最近注意安全,毕竟年底了,查的严,呸,大家注意保暖

特别声明:写该文只是写一下用MobX的思路,有很多地方我会直接放官网链接,因为官网已经写的够详细了

首先来个比较简单的,MobX。

引用官网上的一句话:

MobX 是一个经过战火洗礼的库,它通过透明的函数响应式编程(transparently applying functional reactive programming - TFRP)使得状态管理变得简单和可扩展。MobX背后的哲学很简单:

MobX 是一款精准的状态管理工具库,对我来说非常容易学习和接受。我在 React 和 React Native 应用中使用过 Flux、Alt、Redux 和 Reflux,但我会毫不犹豫地说,MobX 的简单性立即成为了我最喜欢的状态管理工具。我期望能将它运用在未来的项目中,并且对 MobX 的发展拭目以待。

任何源自应用状态的东西都应该自动地获得。其中包括UI、数据序列化、服务器通讯,等等。

上官网的图

React Native中Mobx的使用方法详解

环境我就不配了,官网给了详细的教程,我的环境是RN+TS,这里需要特别注意一下,由于Mobx要用的装饰器,如果单纯的用create-react-app安装好环境后,一定要特别特别注意:

此时使用@observable是不行的,因为不支持装饰器语法,

此问题有两种解决方案:1.在当前环境中设置支持装饰器,

 下面是官网的详细配置链接,https://cn.mobx.js.org/best/decorators.html

  2.使用MobX的内置的 decorate  工具在不支持装饰器语法的情况加使用

接下来下面给你吃,不是,下面我用一个小例子来演示一下,Go,Go,Go(注意,我这里面默认装饰器是可用的,因为我环境配好了已经)

1.yarn add mobx 

2.首先我们状态管理肯定会有一个仓库吧,那我们来建一个仓库,(注意:我创建了两个小的分支,因为状态管理总不可能怼到一个文件里面吧)

首先上一手仓库的结构

React Native中Mobx的使用方法详解 

home.tsx的代码

注意:1. 从mobx中引入observable,action

 2.用装饰器修饰仓库的数据

 3.导出时需要new一下

import { observable, action } from 'mobx'


class List {
 @observable isShowMap: boolean = false

 @action
 switchTab (info: boolean) {
 this.isShowMap = info
 }
}

export default new List()

list.tsx的代码

注意:1.此处多加入了runInAction,不加此属性当然也可以,但是就不会记录时间旅行了

import { observable, action, runInAction } from 'mobx'

class List {
 @observable listData: Array<any> = []

 @action
 getListData () {
 fetch('https://ik9hkddr.qcloud.la/mock/cookbook-list.json')
  .then(reponse => reponse.json())
  .then(result => {
  runInAction(() => {
   this.listData = result.data
  })
  })
 }
}

export default new List()

index.js的代码

注意:在此处将两个树枝里面的数据都引入,合并到一起

import list from './list'
import home from './home'
const store = { list, home }
export default store

3.将仓库绑定到根组件上

     注意:在此引入Provider将仓库和根组件绑定

import React from 'react'
 import { Provider } from 'mobx-react'
 import Home from './pages/home/Home'
 import HotList from './pages/hotlist/HotList'
 import store from './store' 

export default class componentName extends React.Component {
 render() {
 return (
  <Provider store={store}>
  <RootStack></RootStack>
  </Provider>
 )
 }
}}

4.最后一步,在组件中引用仓库里的数据,并可以修改仓库里的数据

  注意:1.引入observer和inject,将组件和仓库连接起来,类似于在React中使用react-redux中的connnect方法

import React from 'react'
import { observer, inject } from 'mobx-react'
import {
 View,
 Text,
} from 'react-native'

interface Props {
}
interface State {
}
//此处时引用最重要的步骤用inject和observer
@inject('store')
@observer
export default class Home extends React.Component<Props, State> {
 render () {
 return (
  <View>
  {/* 引用store里面储存的值 */}
  <Text>{this.props.store.home.isShowMap}</Text>
  </View>
 )
 }
 componentDidMount () {
 //调用函数修改store里面的值
 this.props.store.home.switchTab(value)
 }
}

到这里,今天的随笔已经结束了,可能写的不是那木有条理,若有错误还往各位同学指出,我嗓子已经说不出话来了,所以在这提醒各位同学

 学技术的同时一定要记得锻炼身体,我的天,少吃饭多吃药,多打代码多保健,活着最重要!

 总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
在线编辑器的实现原理(兼容IE和FireFox)
Mar 09 Javascript
JavaScript Object的extend是一个常用的功能
Dec 02 Javascript
基于jquery的tab切换 js原理
Apr 01 Javascript
基于javascript实现按圆形排列DIV元素(三)
Dec 02 Javascript
js实现用户输入的小写字母自动转大写字母的方法
Jan 21 Javascript
详解Vue源码之数据的代理访问
Dec 11 Javascript
微信小程序图表插件wx-charts用法实例详解
May 20 Javascript
vue项目部署到nginx/tomcat服务器的实现
Aug 26 Javascript
JS如何生成随机验证码
Mar 02 Javascript
vue组件开发之slider组件使用详解
Aug 21 Javascript
Vue3 响应式侦听与计算的实现
Nov 11 Javascript
Vue2项目中对百度地图的封装使用详解
Jun 16 Vue.js
element ui table(表格)实现点击一行展开功能
Dec 04 #Javascript
elementUI中Table表格问题的解决方法
Dec 04 #Javascript
zepto.js 实时监听输入框的方法
Dec 04 #Javascript
vue 之 css module的使用方法
Dec 04 #Javascript
Vue源码解析之数组变异的实现
Dec 04 #Javascript
小程序指纹验证的实现代码
Dec 04 #Javascript
js实现下拉框二级联动
Dec 04 #Javascript
You might like
谈PHP生成静态页面分析 模板+缓存+写文件
2009/08/17 PHP
一个简单安全的PHP验证码类、PHP验证码
2016/09/24 PHP
laravel框架之数据库查出来的对象实现转化为数组
2019/10/23 PHP
基于jQuery的消息提示插件 DivAlert之旅(二)
2010/04/01 Javascript
JavaScript高级程序设计(第3版)学习笔记3 js简单数据类型
2012/10/11 Javascript
JQuery实现Ajax加载图片的方法
2015/12/24 Javascript
[原创]Javascript 实现广告后加载 可加载百度谷歌联盟广告
2016/05/11 Javascript
Javascript将双字节字符转换成单字节字符并计算长度
2016/06/22 Javascript
javascript的函数劫持浅析
2016/09/26 Javascript
Node.js批量给图片加水印的方法
2016/11/15 Javascript
在vue-cli脚手架中配置一个vue-router前端路由
2017/07/03 Javascript
angularjs实现简单的购物车功能
2017/09/21 Javascript
vue-swiper的使用教程
2018/08/30 Javascript
vue改变循环遍历后的数据实例
2019/11/07 Javascript
JS实现点星星消除小游戏
2020/03/24 Javascript
微信小程序自定义联系人弹窗
2020/05/26 Javascript
Python学习笔记之常用函数及说明
2014/05/23 Python
Python使用django获取用户IP地址的方法
2015/05/11 Python
python 使用get_argument获取url query参数
2017/04/28 Python
使用Python通过win32 COM实现Word文档的写入与保存方法
2018/05/08 Python
Python + Requests + Unittest接口自动化测试实例分析
2019/12/12 Python
浅谈pytorch中torch.max和F.softmax函数的维度解释
2020/06/28 Python
python 将html转换为pdf的几种方法
2020/12/29 Python
英国领先的男士服装和时尚零售商:Burton
2017/01/09 全球购物
新西兰领先的鞋类和靴子网上商城:Merchant 1948
2017/09/08 全球购物
什么是表空间(tablespace)和系统表空间(System tablespace)
2013/02/25 面试题
校庆团日活动总结
2014/08/28 职场文书
医院领导班子四风对照检查材料
2014/09/27 职场文书
党员批评与自我批评
2014/10/15 职场文书
入党政审材料范文
2014/12/24 职场文书
2015年全国保险公众宣传日活动方案
2015/05/06 职场文书
工作态度不好检讨书
2015/05/06 职场文书
2015年秋季开学典礼校长致辞
2015/07/16 职场文书
《百分数的认识》教学反思
2016/02/19 职场文书
中学教代会开幕词
2016/03/04 职场文书
安装Ruby和 Rails的详细步骤
2022/04/19 Ruby