MobX基础理解

一、介绍

MobX一个状态管理工具,由redux作者亲荐。相比redux来说,更简单,更灵活。

二、核心概念

1.State 状态

state即数据,包括从服务端获取的数据,本地控制组件状态的数据

2.Derivations 派生

任何无需进一步交互的,由state演变而来的都称之为派生(好难翻译)。派生有很多存在形式:

  • 用户接口
  • 派生数据,例如一个列表的length
  • 后端集成例如向服务端发送请求

MobX有两种类型的派生:

  • 计算属性。基于state计算出的一些属性。例如一个任务列表的length。
  • Reactions,state改变时,Reactions会自动执行。运用场景应该是,我们有时候需要在一个状态改变后执行某些操作。

有些初学者喜欢频繁的使用Reactions,但是如果你只是想基于state计算出一些属性,最好使用计算属性。

3. Actions

action就是改变state的代码。action就像是一个用户在单元格里输入一个新值。

明确定义你的action,这可以让你的代码结构更加清晰。在严格模式下,修改state的函数如果没有包裹在actions内,Mobx就不会执行state的修改操作。

换句话说,就是修改state的函数最好包裹在action内,这样可以让你清楚的知道什么地方是在修改状态,方便维护和调试。

三、使用MobX的要领

1.定义你的状态并让它变为可观察的。

状态可以是任意结构的,例如数组或对象。即使是嵌套的数据结构或者引用都没关系。只要你确保,你有想要改变的状态都能被mobx转为可观察的。

import {observable} from ‘mobx‘;
var appState = observable({
    timer: 0
});

2.创建能响应状态变化的视图

import {observer} from ‘mobx-react‘;

@observer
class TimerView extends React.Component {
    render() {
        return (<button onClick={this.onReset.bind(this)}>
                Seconds passed: {this.props.appState.timer}
            </button>);
    }

    onReset () {
        this.props.appState.resetTimer();
    }
};

React.render(<TimerView appState={appState} />, document.body);

3.修改状态

以下代码每隔一秒就会改变你的数据,UI也会随之更新。以下是两个修改状态的例子。

appState.resetTimer = action(function reset() {
    appState.timer = 0;
});

setInterval(action(function tick() {
    appState.timer += 1;
}), 1000);

四、规则

MobX支持单向数据流。

当状态改变时,所有的派生都会自动更新。这就意味着MobX永远都不可能观察到中间值。

所有的派生默认都是同步更新的。这意味着ations能够在修改状态后,安全可靠地观察计算属性。

计算属性都是懒更新的。只要没有用到这个计算属性,它就不会被更新。如果视图从始至终都没有用到这个计算属性,它就会被自动回收。

时间: 2024-12-27 18:35:43

MobX基础理解的相关文章

伪元素、伪类基础理解

前几天同事问我css中单冒号和双冒号是什么意思,我也模糊得很,只有个笼统的概念就是:伪元素和伪类.一直以为,页面布局中很少使用到伪类,结果细细研究发现我们经常使用的hover就是一个最简单的伪类,顿时觉得自己太OUT了,紧跟着这两天都在看这些东西,其实伪类最简单的理解就是用于向某些选择器添加特殊的效果. 具体伪类.伪元素有哪些我就不一一列举,在w3c中列举的很清楚.我主要写写应用的实例. 1.来个简单的,咱们最常用到的向超链接添加不同的颜色: <html> <head> <m

jvm基础理解

一.jvm运行时内存区域 包含堆,虚拟机栈,本地栈(调用native方法时用到),方法区(perm区),程序计数器. 假设32位操作系统,这时系统限制每个进程大小为2G.这样上述这些区域(对于本地栈及程序计数器来讲,是无法设置的,hotspot有提供-Xoss参数用于设置本地方法栈.但实际是无效的)可以用相应参数设置,共同划分全部2G内存. 注意还有一块直接内存,不属于JAVA运行时区域.但是它的空间用得太多的话,还是受限于物理内存和虚拟内存总大小,因此也会抛出OutOfMemory.典型的re

C#委托零基础理解

C#委托零基础理解(转) 1,  为什么使用委托  2.什么是委托  3.委托如何使用 为什么使用委托? 委托是c#中非常重要的一个概念,使用委托使程序员可以将方法引用封装在委托对象内.然后可以将该委托对象传递给可调用所引用方法的代码,而不必在编译时知道将调用哪个方法.与C或C++中的函数指针不同,委托是面向对象,而且是类型安全的. 什么是委托? 委托是一种引用方法的类型,一旦为委托分配了方法,委托将与该方法具有相同的行为,委托方法的使用和其他方法一样,具有参数和返回值. 如何使用委托 下面咱们

初涉网络,自己对服务器的一些基础理解

首先感谢bangumi.tv技术宅真可怕小组的各位提供的指点与帮助 万能的bangumi,请务必不要嫌弃我的无知 因为自己对网络了解较少,所以可能自己的理解有偏差或者因为便于自己理解而不严谨,所以请看到的各位理解(会有人看到吗),希望也不太懂的各位谨慎相信,希望很懂的各位指点. 以下是自己的理解与疑问,摘自bangumi连接. 最近自己学习建立网站,接触了很多云/vps/虚拟主机/服务器 等等很多东西,因为以前对网络方面基本没有了解,所以乱的现在快要爆炸了. 按照我以前的理解,所谓服务器或者云,

2017-2-17,c#基础,输入输出,定义变量,变量赋值,int.Parse的基础理解,在本的初学者也能看懂(未完待续)

计算机是死板的固定的,人是活跃的开放的,初学c#第一天给我的感觉就是:用人活跃开放式的思维去与呆萌的计算机沟通,摸清脾气,有利于双方深入合作,这也是今晚的教训,细心,仔细,大胆 c#基础 1.Hello!World!!! 1 { //输出Hello!World!!; 2 Console.WriteLine("Hello!World!!!"); 3 //防止闪退; 4 Console.ReadLine(); 5 6 } 踏入IT世界的第一步,向世界问好 2.string定义变量 套用向老

零基础理解Binder

写在前面的 当一个Android App存在某个不需要UI的后台运行需求时,或者是因为内存占用需要采用多进程方案时,我们免不了与多进程打交道.必不可少的,需要考虑Binder在其中如何实现. 最常见的Binder实现当然是AIDL,然而Binder的实现绝不仅仅只有AIDL一种方式,如果止步于写.aidl,那么对于Binder,对于Android整体的跨进程传输过程的理解都只能流于形式. 但是想理解Binder不是一件容易的事情,Binder的概念涉及太多知识点,遍观各大论坛上关于Binder的

Deep Learning基础--理解LSTM/RNN中的Attention机制

导读 目前采用编码器-解码器 (Encode-Decode) 结构的模型非常热门,是因为它在许多领域较其他的传统模型方法都取得了更好的结果.这种结构的模型通常将输入序列编码成一个固定长度的向量表示,对于长度较短的输入序列而言,该模型能够学习出对应合理的向量表示.然而,这种模型存在的问题在于:当输入序列非常长时,模型难以学到合理的向量表示. 在这篇博文中,我们将探索加入LSTM/RNN模型中的attention机制是如何克服传统编码器-解码器结构存在的问题的. 通过阅读这篇博文,你将会学习到: 传

Js函数function基础理解

正文:我们知道,在js中,函数实际上是一个对象,每个函数都是Function类型的实例,并且都与其他引用类型一样具有属性和方法.因此,函数名实际上是指向函数对象的指针,不与某个函数绑定.在常见的两种定义方式(见下文)之外,还有一种定义的方式能更直观的体现出这个概念: var sum = new Function("num1", "num2", "return num1 + num2"); //不推荐 Function的构造函数可以接收任意数量的参

Deep Learning基础--理解LSTM网络

循环神经网络(RNN) 人们的每次思考并不都是从零开始的.比如说你在阅读这篇文章时,你基于对前面的文字的理解来理解你目前阅读到的文字,而不是每读到一个文字时,都抛弃掉前面的思考,从头开始.你的记忆是有持久性的. 传统的神经网络并不能如此,这似乎是一个主要的缺点.例如,假设你在看一场电影,你想对电影里的每一个场景进行分类.传统的神经网络不能够基于前面的已分类场景来推断接下来的场景分类. 循环神经网络(Recurrent Neural Networks)解决了这个问题.这种神经网络带有环,可以将信息