Flutter 生命周期

生命周期的基本概念

生么是生命周期

  • 说白了就是回调方法(函数)
  • 让你知道我封装好的这个Widget它处于什么样的状态了!

有什么作用

  • 监听Widget的事件

  • 初始化数据

    • 创建数据
    • 发送网络请求
  • 内存管理

    • 销毁数据、销毁监听者
    • 销毁Timer等等

Widget的生命周期

·Stateless
1、构造方法
2、build方法
Stateful(包含两个对象Widget、State)
  1. Widget构造方法
  2. Widget的Create State
  3. State的构造方法
  4. State的in it State方法
  5. did Change Dependencies方法(改变依赖关系)
    • 依赖的Inherited Widget发生变化之后, 方法也会调用!
  6. State的build
    • 当调用set State方法。会重新调用build进行渲染
  7. 当Widget销毁的时候, 调用State的dispose

·Widget的渲染原理

井不是所有的Widget都会被独立渲染!只有继承Render Object Widget的才会创建Render Object对象|
在Flutter渲染的流程中, 有三颗重要的树!Flutter引擎是针对Render树进行渲染!

  • Widget树、Element树、Render树
    • 每一个Widget都会创建一个Element对象
  • 隐式调用createElement方法。Element加入Element树种
    它会创建三种Element
  • Render Element主要是创建Render Object对象
    继承Render Object Widget的Widget会创建Render Element
    * 创建Ran der Element
    * Flutter会调用mount方法, 调用create Ran der
Object方法
  • Stateful Element继承Component Element
    • Stateful Widget会创建Stateful Element
      • 调用create State方法, 创建State
      • 将Widget赋值给state
      • 调用state的build方法并且将自己(Element) 传出去
        build里面的context就是Widget的Element!
  • Stateless Element继承Component Element
    Stateless Widget会创建Stateless Element
    • 主要就是调用build方法并且将自己(Element) 传出去
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值