flutter mobx狀態(tài)管理

依賴(lài)

dependencies:
  mobx: ^0.1.4
  flutter_mobx: ^0.1.3

dev_dependencies:
  mobx_codegen: ^0.1.3
  build_runner: ^1.4.0

創(chuàng)建對(duì)象

以計(jì)數(shù)例子為例凫佛,創(chuàng)建一個(gè)counter.dart文件浑塞,代碼如下:

import 'package:mobx/mobx.dart';
part 'counter.g.dart';

class Counter = CounterBase with _$Counter;

final Counter counter = Counter();

abstract class CounterBase implements Store {
  @observable
  int count = 0;

  @action
  void add() {
    count++;
  }

  @action
  void minus() {
    count--;
  }

  @action
  void setCount(int value) {
    this.count = value;
  }

  @computed
  bool get isEven => count % 2 == 0;
}

關(guān)于以上代碼的解釋?zhuān)?br> @observable 可觀察對(duì)象借跪,需要在UI層顯示的數(shù)據(jù)可以這樣定義。

 @observable
  int count = 0;

@action 操作方法酌壕,要對(duì)可觀察對(duì)象的值進(jìn)行更改時(shí)掏愁,都應(yīng)該在@action修飾發(fā)方法中進(jìn)行修改歇由,業(yè)務(wù)代碼的操作也是在這個(gè)注解下的方法進(jìn)行。

 @action
 void add() {
    count++;
  }

@computed 計(jì)算果港,基于@observable來(lái)計(jì)算其值的函數(shù)沦泌,如計(jì)算count值是否是偶數(shù),在list中篩選特定條件下的子項(xiàng)等辛掠。

 @computed
 bool get isEven => count % 2 == 0;

注意:必須包含以下兩行代碼谢谦,才可以生成counter.g.dart文件

part 'counter.g.dart';
class Counter = CounterBase with _$Counter;

在命令行中執(zhí)行命令

flutter packages pub run build_runner build

完成后將會(huì)生成counter.g.dart文件
執(zhí)行一下命令,可以實(shí)現(xiàn)counter.g.dart文件的動(dòng)態(tài)生成

flutter packages pub run build_runner watch

即修改counter.dart文件后 ctrl + s(熱重載)即可重新生成公浪。

數(shù)值顯示

在需要顯示count值的時(shí)候,使用如下代碼:
Observer(builder: (_) => Text('${counter.count}')),
Observer是一個(gè)觀察者船侧,繼承了StatefulWidget欠气,將要觀察的組件放置在里面,就能實(shí)現(xiàn)對(duì)該組件的狀態(tài)管理镜撩。

數(shù)值操作

counter.dart中有add()预柒、minus()setCount()三個(gè)方法對(duì)count的值進(jìn)行修改≡#可在按鈕的點(diǎn)擊事件中調(diào)用相關(guān)方法進(jìn)行修改宜鸯,如下:

RaisedButton(
  child: Text('加'),
  onPressed: counter.add,
),

以上就是flutter mobx的簡(jiǎn)單使用方法。
完整代碼案例詳見(jiàn)GitHub:https://github.com/huang-weilong/flutter_state_management

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末遮怜,一起剝皮案震驚了整個(gè)濱河市淋袖,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌锯梁,老刑警劉巖即碗,帶你破解...
    沈念sama閱讀 206,723評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異陌凳,居然都是意外死亡剥懒,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)合敦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)初橘,“玉大人,你說(shuō)我怎么就攤上這事充岛”i埽” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,998評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵崔梗,是天一觀的道長(zhǎng)展东。 經(jīng)常有香客問(wèn)我,道長(zhǎng)炒俱,這世上最難降的妖魔是什么盐肃? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,323評(píng)論 1 279
  • 正文 為了忘掉前任爪膊,我火速辦了婚禮,結(jié)果婚禮上砸王,老公的妹妹穿的比我還像新娘推盛。我一直安慰自己,他們只是感情好谦铃,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布耘成。 她就那樣靜靜地躺著,像睡著了一般驹闰。 火紅的嫁衣襯著肌膚如雪瘪菌。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 49,079評(píng)論 1 285
  • 那天嘹朗,我揣著相機(jī)與錄音师妙,去河邊找鬼。 笑死屹培,一個(gè)胖子當(dāng)著我的面吹牛默穴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播褪秀,決...
    沈念sama閱讀 38,389評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼蓄诽,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了媒吗?” 一聲冷哼從身側(cè)響起仑氛,我...
    開(kāi)封第一講書(shū)人閱讀 37,019評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎闸英,沒(méi)想到半個(gè)月后调衰,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,519評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡自阱,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評(píng)論 2 325
  • 正文 我和宋清朗相戀三年嚎莉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片沛豌。...
    茶點(diǎn)故事閱讀 38,100評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡趋箩,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出加派,到底是詐尸還是另有隱情叫确,我是刑警寧澤,帶...
    沈念sama閱讀 33,738評(píng)論 4 324
  • 正文 年R本政府宣布芍锦,位于F島的核電站竹勉,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏娄琉。R本人自食惡果不足惜次乓,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評(píng)論 3 307
  • 文/蒙蒙 一吓歇、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧票腰,春花似錦城看、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,289評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至缘滥,卻和暖如春轰胁,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背朝扼。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,517評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工赃阀, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人吟税。 一個(gè)月前我還...
    沈念sama閱讀 45,547評(píng)論 2 354
  • 正文 我出身青樓凹耙,卻偏偏與公主長(zhǎng)得像姿现,于是被迫代替她去往敵國(guó)和親肠仪。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 原文 阿里技術(shù) ,傳送門(mén) Flutter簡(jiǎn)介 Flutter的架構(gòu)主要分成三層:Framework提佣,Engine和...
    蓋世英雄_ix4n04閱讀 5,349評(píng)論 1 23
  • 一吮蛹、引言 本文主要對(duì)Flutter工程編譯時(shí)如何把Flutter生成的產(chǎn)物打包進(jìn)入Android工程中進(jìn)行分析。在...
    不喝咖啡的程序員閱讀 14,058評(píng)論 4 79
  • 摘要:閑魚(yú)技術(shù)-正物 問(wèn)題背景 對(duì)于開(kāi)發(fā)者而言拌屏,什么是Flutter潮针?它是用什么語(yǔ)言編寫(xiě)的,包含哪幾部分倚喂,是如何被...
    貓耳呀閱讀 2,541評(píng)論 1 7
  • 從我懂事以來(lái)端圈,我有過(guò)好幾個(gè)這樣的時(shí)刻:很像要一個(gè)孩子焦读,很想去愛(ài)一個(gè)屬于自己的孩子。也非常自信自己會(huì)是一個(gè)很好的母親...
    勇敢Planet閱讀 818評(píng)論 0 0
  • * 鯨落十三 顏清揚(yáng)這一場(chǎng)風(fēng)寒直到打了春才算有些好轉(zhuǎn)舱权,等郊外迎春花開(kāi)矗晃,河水解凍的時(shí)候才算好了七七八八,夜間卻還是咳...
    未辭AZ閱讀 1,416評(píng)論 2 1