React Native中Mobx的使用方法详解
前言
从今天开始我们来搞搞状态管理可否,这几天没怎么写博客,因为被病魔战胜了,tmd,突然的降温让我不知所措,大家最近注意安全,毕竟年底了,查的严,呸,大家注意保暖
特别声明:写该文只是写一下用mobx的思路,有很多地方我会直接放官网链接,因为官网已经写的够详细了
首先来个比较简单的,mobx。
引用官网上的一句话:
mobx 是一个经过战火洗礼的库,它通过透明的函数响应式编程(transparently applying functional reactive programming - tfrp)使得状态管理变得简单和可扩展。mobx背后的哲学很简单:
mobx 是一款精准的状态管理工具库,对我来说非常容易学习和接受。我在 react 和 react native 应用中使用过 flux、alt、redux 和 reflux,但我会毫不犹豫地说,mobx 的简单性立即成为了我最喜欢的状态管理工具。我期望能将它运用在未来的项目中,并且对 mobx 的发展拭目以待。
任何源自应用状态的东西都应该自动地获得。其中包括ui、数据序列化、服务器通讯,等等。
上官网的图
环境我就不配了,官网给了详细的教程,我的环境是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.首先我们状态管理肯定会有一个仓库吧,那我们来建一个仓库,(注意:我创建了两个小的分支,因为状态管理总不可能怼到一个文件里面吧)
首先上一手仓库的结构
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) } }
到这里,今天的随笔已经结束了,可能写的不是那木有条理,若有错误还往各位同学指出,我嗓子已经说不出话来了,所以在这提醒各位同学
学技术的同时一定要记得锻炼身体,我的天,少吃饭多吃药,多打代码多保健,活着最重要!
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
推荐阅读
-
详解iOS App中UISwitch开关组件的基本创建及使用方法
-
React Native学习之Android的返回键BackAndroid详解
-
react中Suspense的使用详解
-
React Native开发中自动打包脚本的实例代码
-
详解HTML5中的Communication API基本使用方法
-
Android 中RxPermissions 的使用方法详解
-
PHP中Closure类的使用方法及详解
-
Python的Django框架中forms表单类的使用方法详解
-
详解Spring Boot中MyBatis的使用方法
-
react native中的聊天气泡及timer封装成的发送验证码倒计时