flutter 生命周期

StatelessWidget

初始化

build

通過build()渲染

StatefulWidget

初始化

State初始化時會依次執(zhí)行 : 構(gòu)造函數(shù) > initState > didChangeDependencies > Widget build , 此時頁面加載完成。

構(gòu)造函數(shù)

調(diào)用次數(shù):1次

這個函數(shù)嚴(yán)格意義上來講不屬于生命周期的一部分,因?yàn)檫@個時候State的widget屬性為空,無法在構(gòu)造函數(shù)中訪問widget的屬性 。但是構(gòu)造函數(shù)必然是要第一個調(diào)用的。可以在這一部分接收前一個頁面?zhèn)鬟f過來的數(shù)據(jù)。

intState

調(diào)用次數(shù):1次

當(dāng)插入渲染樹的時候調(diào)用,這個函數(shù)在生命周期中只調(diào)用一次。這里可以做一些初始化工作,比如初始化State的變量。

在這個方法中,上下文context可用,但你還不能真正使用它,因?yàn)榭蚣苓€沒有完全將狀態(tài)與它相關(guān)聯(lián)

initState()方法完成后,State對象現(xiàn)在已初始化,上下文可用。

didChangeDependencies

  • 初始化時,在initState()之后立刻調(diào)用
  • 當(dāng)依賴的InheritedWidget rebuild,會觸發(fā)此接口被調(diào)用

這個函數(shù)會緊跟在initState之后調(diào)用,并且可以調(diào)用BuildContext.inheritFromWidgetOfExactType, 也就說在didChangeDependencies中,可以跨組件拿到數(shù)據(jù)

在此階段,由于上下文context可用,您可以使用它。

運(yùn)行時

build

調(diào)用次數(shù):多次

初始化之后開始繪制界面,當(dāng)setState觸發(fā)的時候會再次被調(diào)用

didUpdateWidget

這個函數(shù)一般用于比較新、老Widget,看看哪些屬性改變了,并對State做一些調(diào)整。

需要注意的是,涉及到controller的變更,需要在這個函數(shù)中移除老的controller的監(jiān)聽,并創(chuàng)建新controller的監(jiān)聽。

組件移除

組件移除,例如頁面銷毀的時候會依次執(zhí)行:deactivate > dispose

deactivate

在dispose之前,會調(diào)用這個函數(shù)。實(shí)測在組件課件狀態(tài)變化的時候會調(diào)用,當(dāng)組件卸載時也會先一步dispose調(diào)用。

dispose

調(diào)用次數(shù):1次

hot reload

reassemble

一旦到這個階段,組件就要被銷毀了,這個函數(shù)一般會移除監(jiān)聽,清理環(huán)境。

State

State鏈接到一個BuildContext,BuildContext鏈接到Widget的一個實(shí)例

widget

Widget State類訪問其任何變量

print(widget.title);

currentState

父Widget可以通過以下方式訪問其子級的狀態(tài)

SnackBar是Scaffold的子Widget

final GlobalKey<ScaffoldState> _scaffoldKey = GlobalKey<ScaffoldState>();

new Scaffold(
  key: _scaffoldKey,
  appBar: new AppBar(
    title: new Text(widget.title == null ? 'ADD' : 'EDIT'),
  ),
  body: new Container(
    padding: EdgeInsets.all(20.0),
    child: new Column(
      mainAxisAlignment: MainAxisAlignment.start,
      children: <Widget>[
        new Container(
          margin: EdgeInsets.fromLTRB(0, 20, 0, 0),
          child: new RaisedButton(
            color: Colors.purple,
            textColor: Color(0xFFFFFFFF),
            onPressed: () {
              _scaffoldKey.currentState.showSnackBar(
                SnackBar(content: Text('Not supported.'))
              );
            },
            child: new Text('保存'),
          ),
        )
      ],
    ),
  )
);

還有一種也可以實(shí)現(xiàn)類似currentState的功能

floatingActionButton: ScaffoldButton(
  onPressedButton: () {
    _incrementCounter();
  },
));

class ScaffoldButton extends StatelessWidget {
  ScaffoldButton({this.onPressedButton});

  final VoidCallback onPressedButton;

  @override
  Widget build(BuildContext context) {
    return FloatingActionButton(
      onPressed: () {
        print(
            'FloatingActionButton onPressed context hashcode = ${context.hashCode}');
        Scaffold.of(context).showSnackBar(
            SnackBar(content: Text('I am context from Scaffold')));
        onPressedButton();
      },
      tooltip: 'Increment',
      child: new Icon(Icons.add),
    );
  }
}

祖先Widget

final MyExposingWidget widget = context.ancestorWidgetOfExactType(MyExposingWidget);
final MyExposingWidgetState state = widget?.myState;

InheritedWidget

InheritedWidget是一個特殊的Widget,您可以將其作為另一個子樹的父級放在Widgets樹中。該子樹的所有小部件都必須能夠與該InheritedWidget公開的數(shù)據(jù)進(jìn)行交互。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,885評論 6 541
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,312評論 3 429
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,993評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,667評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,410評論 6 411
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,778評論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,775評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,955評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,521評論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,266評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,468評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,998評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,696評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,095評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,385評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,193評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,431評論 2 378

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