Flutterflutter学习

Flutter生命周期详解

2019-03-13  本文已影响6人  wayDevelop

github地址

生命周期是一个组件加载到卸载的整个周期,熟悉生命周期可以让我们在合适的时机做该做的事情,
flutter中的State生命周期和android以及React Native的生命周期类似。
组件State的生命周期整理:


image.png

大致可以分为3个阶段:

初始化

State初始化时会依次执行 : 构造函数 > initState > didChangeDependencies > Widget build , 此时页面加载完成。

2019-03-13 19:06:22.258 18494-18527/com.example.flutter_app I/flutter: -------构造函数
2019-03-13 19:06:22.259 18494-18527/com.example.flutter_app I/flutter: -------init state
2019-03-13 19:06:22.259 18494-18527/com.example.flutter_app I/flutter: -------didChangeDependencies
2019-03-13 19:06:22.261 18494-18527/com.example.flutter_app I/flutter: -------widget build

状态变化(热重载)

操作:横竖屏切换
其他生命周期并没有执行
竖屏切换到横屏执行2次
横屏切换到竖屏执行2次

com.example.flutter_app I/flutter: -------reassemble
com.example.flutter_app I/flutter: -------组件状态改变:didUpdateWidget
com.example.flutter_app I/flutter: -------widget build

组件移除

组件移除,例如页面销毁的时候会依次执行:deactivate > dispose

01-15 14:08:40.956 19005-19561/com.example.flutter_app I/flutter: deactivate
01-15 14:08:40.970 19005-19561/com.example.flutter_app I/flutter: dispose

各个方法的解释:

didChangeDependencies有两种情况会被调用。

创建时候在initState 之后被调用
在依赖的InheritedWidget发生变化的时候会被调用

正常的退出流程中会执行deactivate然后执行dispose。但是也会出现deactivate以后不执行dispose,直接加入树中的另一个节点的情况。

这里的状态改变包括两种可能:1.通过setState内容改变 2.父节点的state状态改变,导致孩子节点的同步变化。

image.png
参考文章
上一篇 下一篇

猜你喜欢

热点阅读