Flutter開發(fā)-Widget的生命周期

一拖吼、Flutter?頁面生命周期

Flutter 頁面生命周期就是 Flutter 頁面組件 Widget 的生命周期 ;

頁面的組件就是 StatefulWidget 組件 和 StatelessWidget 組件 ;

1鳞上、StatelessWidget 組件生命周期函數

StatelessWidget 組件生命周期函數 :?只有兩個 , 分別是 createElement() , build() 兩個方法 ;

abstract class StatelessWidget extends Widget {

? /// Initializes [key] for subclasses.

? const StatelessWidget({ Key key }) : super(key: key);


? @override

? StatelessElement createElement() => StatelessElement(this);

? @protected

? Widget build(BuildContext context);

}


2、StatefulWidget 組件生命周期函數

StatefulWidget 組件生命周期分為三組 :

① 初始化期 : createState , initState ;

② 更新期 : didChangeDependencies , build , didUpdateWidget ;

③ 銷毀期 : deactivate , dispose ;

二吊档、StatefulWidget 組件生命周期


1篙议、createState

createState 函數 :

所處時期 :?初始化期的生命周期函數

調用時機 :?創(chuàng)建 StatefulWidget 之后調用的第一個方法 ;

抽象方法 :?該方法是抽象方法 , 必須覆蓋重寫該方法 ;

/// 1. 初始化期的生命周期函數

? /// 創(chuàng)建 StatefulWidget 之后調用的第一個方法 ,

? /// 該方法是抽象方法 , 必須覆蓋

? @override

? _WidgetLiftCyclePageState createState() => _WidgetLiftCyclePageState();


2、initState

initState 函數 :

所處時期 : 初始化期的生命周期函數

調用時機 : 該方法是創(chuàng)建 Widget 組件時除構造方法之外的第一個方法 ,

對應方法 : 對應 Android 中的 onCreate 方法 ; 對應 iOS 中的 viewDidLoad 方法 ;

常用用法 : 在該方法中執(zhí)行一些初始化操作 ;

/// 2. 初始化期的生命周期函數

? /// 該方法是創(chuàng)建 Widget 組件時除構造方法之外的第一個方法

? /// 該方法對應 Android 中的 onCreate 方法

? /// 對應 iOS 中的 viewDidLoad 方法

? /// 常用用法 : 在該方法中執(zhí)行一些初始化操作

? @override

? void initState() {

? ? print("initState");

? ? super.initState();

? }


3怠硼、didChangeDependencies

didChangeDependencies 函數 :

所處時期 : 更新期的生命周期函數 ;

調用時機 : ① 創(chuàng)建 Widget 組件時 , 調用完 initState 方法后 , 調用該方法 ; ② InheritedWidget 相關 ( 暫不涉及 ) ;

/// 3. 更新期的生命周期函數

? /// 方法調用時機 :

? /// ① 創(chuàng)建 Widget 組件時 , 調用完 initState 方法后 , 調用該方法

? /// ② InheritedWidget 相關 ( 暫不涉及 )

? @override

? void didChangeDependencies() {

? ? /// 該方法在開始處必須調用父類的方法

? ? super.didChangeDependencies();

? ? print("didChangeDependencies");

? }


4鬼贱、build

build 函數 :

所處時期 : 更新期的生命周期函數 ;

調用時機 : ① 調用完 didChangeDependencies 方法后調用該方法 ; ② 調用 setState 方法之后 , 該方法也會被調用 ;

方法作用 : 頁面每次渲染時都會調用該方法 ;

/// 4. 更新期的生命周期函數

? /// 方法調用時機 :

? /// ① 調用完 didChangeDependencies 方法后調用該方法

? /// ② 調用 setState 方法之后 , 該方法也會被調用 ;

? /// 頁面每次渲染時都會調用該方法

? @override

? Widget build(BuildContext context) {

? ? print("build");

? ? return Scaffold(

? ? ? appBar: AppBar(

? ? ? ? // 標題

? ? ? ? title: Text("StatefulWidget 頁面生命周期"),

? ? ? ? // 回退按鈕

? ? ? ? leading: BackButton(),

? ? ? ),

? ? ? body: Center(

? ? ? ? child: Column(

? ? ? ? ? children: <Widget>[

? ? ? ? ? ? RaisedButton(

? ? ? ? ? ? ? // 點擊事件

? ? ? ? ? ? ? onPressed: (){

? ? ? ? ? ? ? ? // 回調更新期 生命周期函數

? ? ? ? ? ? ? ? setState(() {

? ? ? ? ? ? ? ? });

? ? ? ? ? ? ? },

? ? ? ? ? ? ? child: Text("調用 setState() 方法"),

? ? ? ? ? ? ),

? ? ? ? ? ],

? ? ? ? ),

? ? ? ),

? ? );

? }


5、didUpdateWidget

didUpdateWidget 函數 :

所處時期 : 更新期的生命周期函數 ;

調用時機 : 該生命周期方法不經常調用 , 只有在父容器組件重繪時才調用該方法 ;

方法機制 : 傳入的 oldWidget 參數是舊的組件信息 , 將當前的 Widget 與舊的 Widget 進行對比 , 如果不相等 , 便執(zhí)行額外操作 ;

/// 5. 更新期的生命周期函數

? /// 方法調用時機 : 該生命周期方法不經常調用 , 只有在父容器組件重繪時才調用該方法

? /// 方法機制 : 傳入的 oldWidget 參數是舊的組件信息 ,

? /// 將當前的 Widget 與舊的 Widget 進行對比 , 如果不相等 , 便執(zhí)行額外操作

? /// 如 : 組件的屬性不相等 , 字段的值不相等

? @override

? void didUpdateWidget(WidgetLiftCyclePage oldWidget) {

? ? super.didUpdateWidget(oldWidget);

? ? print("didUpdateWidget");

? }


6香璃、deactivate

deactivate 函數 :

所處時期 :?銷毀期的生命周期函數 ;

調用時機 :?該生命周期方法不經常調用 , 只有在組件被移除時才調用 ;

/// 6 . 銷毀期的生命周期函數

? /// 方法調用時機 : 該生命周期方法不經常調用 , 只有在組件被移除時才調用

? /// 該方法在 dispose 方法之前被調用

? @override

? void deactivate() {

? ? super.deactivate();

? ? print("deactivate");

? }


7这难、dispose

dispose 函數 :

所處時期 :?銷毀期的生命周期函數 ;

調用時機 :?組件被銷毀時調用 , 要在該方法中進行資源的釋放與銷毀操作 ;

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市增显,隨后出現的幾起案子雁佳,更是在濱河造成了極大的恐慌,老刑警劉巖同云,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件糖权,死亡現場離奇詭異,居然都是意外死亡炸站,警方通過查閱死者的電腦和手機星澳,發(fā)現死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來旱易,“玉大人禁偎,你說我怎么就攤上這事》Щ担” “怎么了如暖?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長忌堂。 經常有香客問我盒至,道長,這世上最難降的妖魔是什么士修? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任枷遂,我火速辦了婚禮,結果婚禮上棋嘲,老公的妹妹穿的比我還像新娘酒唉。我一直安慰自己,他們只是感情好沸移,可當我...
    茶點故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布痪伦。 她就那樣靜靜地躺著侄榴,像睡著了一般。 火紅的嫁衣襯著肌膚如雪网沾。 梳的紋絲不亂的頭發(fā)上牲蜀,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天,我揣著相機與錄音绅这,去河邊找鬼。 笑死在辆,一個胖子當著我的面吹牛证薇,可吹牛的內容都是我干的。 我是一名探鬼主播匆篓,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼浑度,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了鸦概?” 一聲冷哼從身側響起箩张,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎窗市,沒想到半個月后先慷,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡咨察,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年论熙,在試婚紗的時候發(fā)現自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片摄狱。...
    茶點故事閱讀 40,505評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡脓诡,死狀恐怖,靈堂內的尸體忽然破棺而出媒役,到底是詐尸還是另有隱情祝谚,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布酣衷,位于F島的核電站交惯,受9級特大地震影響,放射性物質發(fā)生泄漏鸥诽。R本人自食惡果不足惜商玫,卻給世界環(huán)境...
    茶點故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望牡借。 院中可真熱鬧拳昌,春花似錦、人聲如沸钠龙。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至沈矿,卻和暖如春上真,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背羹膳。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工睡互, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人陵像。 一個月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓就珠,卻偏偏與公主長得像,于是被迫代替她去往敵國和親醒颖。 傳聞我的和親對象是個殘疾皇子妻怎,可洞房花燭夜當晚...
    茶點故事閱讀 45,515評論 2 359

推薦閱讀更多精彩內容