Flutter生命周期超詳細(xì)講解
一 這里看一下StatefulWidget的生命周期
其本身是由兩個(gè)類(lèi)組成的,StatefulWidget 和 State 組成的。
class DemoWidget extends StatefulWidget { const DemoWidget({super.key}); @override State<DemoWidget> createState() => _DemoWidgetState(); } class _DemoWidgetState extends State<DemoWidget> { @override Widget build(BuildContext context) { return Container(); } }
首先
會(huì)執(zhí)行StatefulWidget 中相關(guān)的方法
* 1 執(zhí)行StatefulWidget的構(gòu)造函數(shù)(Constructor)來(lái)創(chuàng)建StatefuleWidget
* 2 執(zhí)行StateWidget的createState 方法,來(lái)創(chuàng)建一個(gè)維護(hù)StatefulWidget 的State對(duì)象
其次
調(diào)用createState 創(chuàng)建State對(duì)象時(shí)候,執(zhí)行State類(lèi)相關(guān)的方法
* 1 執(zhí)行State 類(lèi)的構(gòu)造方法(Constructor)來(lái)創(chuàng)建State 對(duì)象
* 2 執(zhí)行initState,我們通常會(huì)在這個(gè)方法中執(zhí)行一些數(shù)據(jù)初始化的操作或者也可能發(fā)送數(shù)據(jù)請(qǐng)求
@override void initState() { super.initState(); }
* 3 執(zhí)行didChangeDependencies 方法,這個(gè)方法會(huì)在兩種情況下調(diào)用
- 調(diào)用initState 會(huì)調(diào)用
- 從其他對(duì)象依賴一些數(shù)據(jù)發(fā)生改變的時(shí)候,會(huì)調(diào)用
* 4 執(zhí)行build 方法,來(lái)看一下當(dāng)前的widget 需要渲染哪些Widget,構(gòu)建對(duì)應(yīng)的widgets
* 5 當(dāng)前的widget 不再使用的時(shí)候,會(huì)調(diào)用dispose 進(jìn)行銷(xiāo)毀
* 6 手動(dòng)調(diào)用setState方法,會(huì)根據(jù)最新的狀態(tài)(數(shù)據(jù)) 開(kāi)重新調(diào)用build 方法,構(gòu)建對(duì)應(yīng)的Widgets
* 7 執(zhí)行didUpdateWidget 方法是當(dāng)父Widget 觸發(fā)重建(rebuild)時(shí),系統(tǒng)會(huì)調(diào)用didUpdateWidget方法
二 SetState
/// Marks the element as dirty and adds it to the global list of widgets to /// rebuild in the next frame. /// /// Since it is inefficient to build an element twice in one frame, /// applications and widgets should be structured so as to only mark /// widgets dirty during event handlers before the frame begins, not during /// the build itself. void markNeedsBuild() { void scheduleBuildFor(Element element) if (_dirty) { owner!.scheduleBuildFor(this); } if (hadDependencies) { didChangeDependencies(); } } /// Adds an element to the dirty elements list so that it will be rebuilt /// when [WidgetsBinding.drawFrame] calls [buildScope]. void scheduleBuildFor(Element element) { }
setState的調(diào)用 其實(shí)是element 會(huì)調(diào)用 markNeedsBuild 這個(gè)方法,標(biāo)記當(dāng)前的element 需要更新。dirty 設(shè)置為true.
方法的最后會(huì)調(diào)用一個(gè)BuildOwner類(lèi)中的
scheduleBuildFor 方法,這個(gè)方法注釋寫(xiě)的很清楚,就是吧這個(gè)element 添加到dirty elements list 中去,當(dāng)WidgetsBinding.drawFrame 去走更新的流程
when [WidgetsBinding.drawFrame] calls [buildScope].
到此這篇關(guān)于Flutter生命周期超詳細(xì)講解的文章就介紹到這了,更多相關(guān)Flutter生命周期內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
kotlin使用Dagger2的過(guò)程全紀(jì)錄
Dagger2是一款基于Java注解,在編譯階段完成依賴注入的開(kāi)源庫(kù),主要用于模塊間解耦,方便進(jìn)行測(cè)試。下面這篇文章主要給大家介紹了關(guān)于kotlin使用Dagger2的過(guò)程的相關(guān)資料,需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-03-03Android之Viewpager+Fragment實(shí)現(xiàn)懶加載示例
本篇文章主要介紹了Android之Viewpager+Fragment實(shí)現(xiàn)懶加載示例,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03Android購(gòu)物車(chē)項(xiàng)目快速開(kāi)發(fā)
這篇文章主要為大家詳細(xì)介紹了Android購(gòu)物車(chē)項(xiàng)目快速開(kāi)發(fā),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01Android實(shí)現(xiàn)上下菜單雙向滑動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)上下菜單雙向滑動(dòng)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01Flutter進(jìn)階之實(shí)現(xiàn)動(dòng)畫(huà)效果(二)
這篇文章主要為大家詳細(xì)介紹了Flutter進(jìn)階之實(shí)現(xiàn)動(dòng)畫(huà)效果的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08android studio xml文件實(shí)現(xiàn)添加注釋
這篇文章主要介紹了android studio xml文件實(shí)現(xiàn)添加注釋?zhuān)哂泻芎玫膮⒖純r(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-03-03Android獲取手機(jī)的版本號(hào)等信息的代碼
這篇文章主要為大家詳細(xì)介紹了Android獲取手機(jī)的版本號(hào)等信息的代碼,代碼很精彩,感興趣的小伙伴們可以參考一下2016-07-07Android10 App 啟動(dòng)分析進(jìn)程創(chuàng)建源碼解析
這篇文章主要為大家介紹了Android10 App啟動(dòng)分析進(jìn)程創(chuàng)建源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10