flutter的widget的执行顺序,单个组建的执行顺序

Flutter Widget 执行顺序详解

单个 Widget 的执行顺序

在 Flutter 中,单个 Widget 的生命周期执行顺序如下:

1. 创建阶段 (Creation)

  • 构造函数:Widget 首先通过构造函数被创建

  • createState():对于 StatefulWidget,会调用 createState() 方法创建对应的 State 对象

2. 初始化阶段 (Initialization)

  • initState():StatefulWidget 的 State 对象被插入到树中时调用(只调用一次)

  • didChangeDependencies():在 initState() 之后立即调用,或当依赖的 InheritedWidget 发生变化时调用

3. 构建阶段 (Building)

  • build():构建 Widget 的 UI 表示,这个方法会被频繁调用

4. 更新阶段 (Update)

  • didUpdateWidget():当父 Widget 重建并需要更新当前 Widget 时调用

  • setState():触发 Widget 重新构建

5. 销毁阶段 (Disposal)

  • deactivate():当 State 从树中移除时调用

  • dispose():当 State 对象被永久移除时调用(释放资源)

完整执行顺序流程图

text

复制代码
构造函数 → createState() (仅Stateful) → initState() → didChangeDependencies() → build()
       ↑                                ↓
       ←────── didUpdateWidget() ←───────
       ↓
deactivate() → dispose()

不同类型 Widget 的执行差异

StatelessWidget

  1. 构造函数

  2. build()

StatefulWidget

  1. 构造函数

  2. createState()

  3. State 类的构造函数

  4. initState()

  5. didChangeDependencies()

  6. build()

  7. (更新时) didUpdateWidget()

  8. (销毁时) deactivate()

  9. dispose()

重要说明

  • build() 方法:可能被频繁调用,应保持轻量级

  • initState():适合执行一次性初始化操作

  • dispose():必须释放所有控制器、订阅等资源

  • 热重载:会重新创建 Widget 但保留 State,触发 build() 但不触发 initState()

理解这些执行顺序对于正确管理 Widget 生命周期和状态至关重要。

相关推荐
SoaringHeart19 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
月光下的丝瓜2 天前
Flutter 国内安装指南
前端·flutter
恋猫de小郭4 天前
Amper 正式转正 Kotlin Toolchain ,Gradle 未来何去何从
android·前端·flutter
张风捷特烈4 天前
Flutter 类库大揭秘#02 | path_provider 各平台实现
前端·flutter
TT_Close5 天前
别劝退了!5秒搞定 Flutter 鸿蒙 FVM 起跑线
flutter·harmonyos·visual studio code
你听得到115 天前
用户说 App 卡,但说不清在哪?我把 Flutter 监控 SDK 升级成了链路观测工作台
前端·flutter·性能优化
stringwu7 天前
Flutter 开发必备:MVI 架构的高效实现指南
前端·flutter
程序员老刘8 天前
Flutter版本选择指南:3.44系列继续观望 | 2026年6月
flutter·ai编程·客户端
用户965597361909 天前
Provider vs Bloc vs GetX vs Riverpod:Flutter 状态管理方案怎么选?
flutter
恋猫de小郭9 天前
Flutter Patchwork,不用 Fork 改依赖包源码的第三方工具
android·前端·flutter