flutter 狀態(tài)管理 Provider

本文只簡(jiǎn)單介紹Provider的用法和使用中遇到的問(wèn)題

2019 Google I/O 大會(huì)上误趴,官方正式介紹了 由社區(qū)作者 [Remi Rousselet] 與 Flutter Team 共同編寫的 [Provider] 代替 Provide 成為官方推薦的狀態(tài)管理方式之一前计。下面以最簡(jiǎn)單的計(jì)數(shù)器為例。

1.在pubspec.yaml中引入Provider 包

dependencies:
  flutter:
    sdk: flutter
  provider : ^3.0.0+1

2.新建CouterProvider

import 'package:flutter/material.dart';

class CounterBloc with ChangeNotifier {  //混入 
  int _counter = 0;

  int get counter => _counter; //將couter 暴露出去

  increment() {
    _counter++;
    notifyListeners(); // 通知狀態(tài)改變
  }

  decrement() {
    _counter--;
    notifyListeners();
  }
}

3.在頂層注入Provider

import 'package:provider/provider.dart';
import './provide/couter.dart';

void main() {
  Provider.debugCheckInvalidValueType = null;     /*** Provider如果與Listenable/一起使用,現(xiàn)在拋出Stream苟穆〖巳蹋考慮使用ListenableProvider/ StreamProvider代替〕⑽或者铛只,可以通過(guò)設(shè)置Provider.debugCheckInvalidValueType 為null這樣來(lái)禁用此異常***/

  runApp(
    MultiProvider(   //使用MultiProvider可管理多個(gè)Provider
      providers: [
        ChangeNotifierProvider(builder: (_) => HomeProvide()),
      ],
      child: MyApp(),
    ),
  );
}

4.頁(yè)面獲取數(shù)據(jù)和改變數(shù)據(jù)

// 方法一 通過(guò)Provider.of<CounterBloc>(context) 獲取數(shù)據(jù)方法
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    final counter =Provider.of<CounterBloc>(context);     // 拿到Provider
    return Scaffold(
      appBar: AppBar(title: Text('provider計(jì)數(shù)器'),),
      floatingActionButton: FloatingActionButton(
        onPressed: (){
          Provider.of<CounterBloc>(context, listen: false).increment();   /*** 調(diào)用增加方法,ChangeNotifierProvider通知依賴重建Widget 糠溜,此處特別注意listen:false,如果[listen]為“true”(默認(rèn))淳玩,則以后的值更改將觸發(fā)小部件的新[state.build]和的[state.didchangeDependencies],,數(shù)據(jù)將會(huì)無(wú)限請(qǐng)求***/
        },
        child: Icon(Icons.add),
      ),
      body: Container(
        child: Center(
          child: Text('${counter.counter}'),   
        ),
      ),
    );
  }
}
// 方法二: 通過(guò)Consumer獲取數(shù)據(jù)
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    final counter =Provider.of<CounterBloc>(context);
    return Consumer(
      builder: (context,CounterBloc counter,_){
        return Scaffold(
          appBar: AppBar(title: Text('Provider計(jì)數(shù)器'),),
          floatingActionButton: FloatingActionButton(
            onPressed: (){},
            child: Icon(Icons.add),
          ),
          body: Container(
            child: Center(
              child: Text(counter.counter.toString()),
            ),
          ),
        );
      },
    );
  }
}

4.注意事項(xiàng)
Provider.of<T>(context) 會(huì)導(dǎo)致調(diào)用的 context 頁(yè)面范圍的刷新非竿。
Consumer 只刷新了 Consumer 的部分
建議盡量使用 Consumer 而不是 Provider.of<T>(context) 獲取頂層數(shù)據(jù)
特別注意盡量保證build 無(wú)副作用蜕着,不然頁(yè)面經(jīng)常重繪

如有不對(duì),請(qǐng)指正

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末汽馋,一起剝皮案震驚了整個(gè)濱河市侮东,隨后出現(xiàn)的幾起案子圈盔,更是在濱河造成了極大的恐慌,老刑警劉巖悄雅,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件驱敲,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡宽闲,警方通過(guò)查閱死者的電腦和手機(jī)众眨,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)容诬,“玉大人娩梨,你說(shuō)我怎么就攤上這事±劳剑” “怎么了狈定?”我有些...
    開(kāi)封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)习蓬。 經(jīng)常有香客問(wèn)我纽什,道長(zhǎng),這世上最難降的妖魔是什么躲叼? 我笑而不...
    開(kāi)封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任芦缰,我火速辦了婚禮,結(jié)果婚禮上枫慷,老公的妹妹穿的比我還像新娘让蕾。我一直安慰自己,他們只是感情好或听,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布探孝。 她就那樣靜靜地躺著,像睡著了一般神帅。 火紅的嫁衣襯著肌膚如雪再姑。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天找御,我揣著相機(jī)與錄音元镀,去河邊找鬼。 笑死霎桅,一個(gè)胖子當(dāng)著我的面吹牛栖疑,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播滔驶,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼遇革,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起萝快,我...
    開(kāi)封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤锻霎,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后揪漩,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體旋恼,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年奄容,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了冰更。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡昂勒,死狀恐怖蜀细,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情戈盈,我是刑警寧澤奠衔,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站奕谭,受9級(jí)特大地震影響涣觉,放射性物質(zhì)發(fā)生泄漏痴荐。R本人自食惡果不足惜血柳,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望生兆。 院中可真熱鬧难捌,春花似錦、人聲如沸鸦难。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)合蔽。三九已至击敌,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間拴事,已是汗流浹背沃斤。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留刃宵,地道東北人衡瓶。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像牲证,于是被迫代替她去往敵國(guó)和親哮针。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345