React Native 中 MobX使用

MobX 通過透明的函數(shù)響應式編程(transparently applying functional reactive programming - TFRP)使得狀態(tài)管理變得簡單和可擴展。
MobX背后的哲學很簡單:

任何源自應用狀態(tài)的東西都應該自動地獲得窗怒,其中包括UI映跟、數(shù)據(jù)序列化、服務器通訊扬虚,等等申窘。

flow.png

一、安裝

  • 安裝:
npm install mobx --save
  • 安裝React 綁定庫:
npm install mobx-react --save
  • 安裝啟用 ESNext 的裝飾器-@ (可選)
npm i --save-dev babel-plugin-transform-decorators-legacy

然后在 .babelrc 文件中啟用它:

{
  "presets": ["react-native"],
  "plugins": ["transform-decorators-legacy"]
}

二孔轴、MobX 要點

  • Observable state(可觀察的狀態(tài))
    MobX 為現(xiàn)有的數(shù)據(jù)結(jié)構(gòu)(如對象剃法,數(shù)組和類實例)添加了可觀察的功能。
    通過使用 @observable 裝飾器(ES.Next)來給你的類屬性添加注解就可以簡單地完成這一切路鹰。
    這些 @ 開頭的東西是ES.next裝飾器(可選)贷洲。
    如果不支持裝飾器或字段初始化器,那么 @observable key = value; 會是 extendObservable(this, { key: value }) 的語法糖晋柱。
 import { observable } from 'mobx';

 @observable title = "observable";
  • Computed values(計算值)
    在相關(guān)數(shù)據(jù)發(fā)生變化時自動更新的值优构。
  1. 可以在任意類屬性的 getter 上使用 @computed 裝飾器來聲明式的創(chuàng)建計算屬性。
import {observable, computed} from "mobx";

class Apple {
    @observable price = 0;
    @observable amount = 1;

    constructor(price) {
        this.price = price;
    }

    @computed get totalPrice() {
        return this.price * this.amount;
    }
}
  1. 可以為計算值定義 setter雁竞。注意這些 setters 不能用來直接改變計算屬性的值钦椭,但是它們可以用來作“逆向”衍生拧额。
class Foo {
    @observable length = 2;
    @computed get squared() {
        return this.length * this.length;
    }
    set squared(value) { // 這是一個自動的動作,不需要注解
        this.length = Math.sqrt(value);
    }
}
*注意: 永遠在 getter 之后 定義 setter彪腔,一些 TypeScript 版本會知道聲明了兩個具有相同名稱的屬性侥锦。
*注意: setter 需要 MobX 2.5.1 或者更高版本
  1. 可以直接當做函數(shù)來調(diào)用,在返回的對象上使用 .get() 來獲取計算的當前值德挣,或者使用 .observe(callback) 來觀察值的改變恭垦。
import {observable, computed} from "mobx";
var name = observable("John");

var upperCaseName = computed(() =>
    name.get().toUpperCase()
);

var disposer = upperCaseName.observe(change => console.log(change.newValue));

name.set("Dave");
// 輸出: 'DAVE'
  • Autorun
    當使用 autorun 時,所提供的函數(shù)總是立即被觸發(fā)一次格嗅,然后每次它的依賴關(guān)系改變時會再次被觸發(fā)番挺。
  • observer
    用來將 React 組件轉(zhuǎn)變成響應式組件。 它用 mobx.autorun 包裝了組件的 render 函數(shù)以確保任何組件渲染中使用的數(shù)據(jù)變化時都可以強制刷新組件屯掖。 observer 是由單獨的 mobx-react 包提供的玄柏。
import { observer } from 'mobx-react';

var timerData = observable({
  secondsPassed: 0,
});

setInterval(() => {
  timerData.secondsPassed++;
}, 1000);

@observer
class Timer extends React.Component {
  render() {
    return <Text>{timerData.secondsPassed}</Text>;
  }
}
*注意,使用 @observer 裝飾器是可選的贴铜,它和 observer(class Timer ... { }) 達到的效果是一樣的粪摘。
  • action (動作)
    用法:
    action(fn)
    action(name, fn)
    @action classMethod() {}
    @action(name) classMethod () {}
    @action boundClassMethod = (args) => { body }
    @action(name) boundClassMethod = (args) => { body }
    @action.bound classMethod() {}
    @action.bound(function() {})

任何應用都有動作。動作是任何用來修改狀態(tài)的東西阀湿。 使用MobX你可以在代碼中顯式地標記出動作所在的位置赶熟。 動作可以有助于更好的組織代碼瑰妄。

應該永遠只對修改狀態(tài)的函數(shù)使用動作陷嘴。 只執(zhí)行查找,過濾器等函數(shù)不應該被標記為動作

class Ticker {
    @observable tick = 0

    @action.bound
    increment() {
        this.tick++ // 'this' 永遠都是正確的
    }
}

const ticker = new Ticker()
setInterval(ticker.increment, 1000)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末间坐,一起剝皮案震驚了整個濱河市灾挨,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌竹宋,老刑警劉巖劳澄,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異蜈七,居然都是意外死亡秒拔,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門飒硅,熙熙樓的掌柜王于貴愁眉苦臉地迎上來砂缩,“玉大人,你說我怎么就攤上這事三娩♀职牛” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵雀监,是天一觀的道長双吆。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么好乐? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任匾竿,我火速辦了婚禮,結(jié)果婚禮上曹宴,老公的妹妹穿的比我還像新娘搂橙。我一直安慰自己,他們只是感情好笛坦,可當我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布区转。 她就那樣靜靜地躺著,像睡著了一般版扩。 火紅的嫁衣襯著肌膚如雪废离。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天礁芦,我揣著相機與錄音蜻韭,去河邊找鬼。 笑死柿扣,一個胖子當著我的面吹牛肖方,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播未状,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼俯画,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了司草?” 一聲冷哼從身側(cè)響起艰垂,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎埋虹,沒想到半個月后猜憎,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡搔课,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年胰柑,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片爬泥。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡柬讨,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出急灭,到底是詐尸還是另有隱情姐浮,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布葬馋,位于F島的核電站卖鲤,受9級特大地震影響肾扰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蛋逾,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一集晚、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧区匣,春花似錦偷拔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至姑丑,卻和暖如春蛤签,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背栅哀。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工震肮, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人留拾。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓戳晌,卻偏偏與公主長得像,于是被迫代替她去往敵國和親痴柔。 傳聞我的和親對象是個殘疾皇子沦偎,可洞房花燭夜當晚...
    茶點故事閱讀 43,452評論 2 348