首页
学习
活动
专区
圈层
工具
发布

StatefulWidget与State

StatefulWidget 首先来看下StatefulWidget,它是一个抽象类,当然它十分的简单。...: 初始化:插入渲染树,这一阶段涉及的生命周期函数主要有createState、initState、didChangeDependencies和build。...运行中:在渲染树中存在,这一阶段涉及的生命周期函数主要有didUpdateWidget和build。 销毁:从渲染树中移除,此阶段涉及的生命周期函数主要有deactivate和dispose。...然后判断state状态如果是created而且此时的Element不为空(mounte实际上就是表示Element的状态) 执行传入的函数体 判断函数体返回是不是一个Future,如果是就抛异常提示处理...小结 StatefulWidget是由状态组建,我们可以使用setState方法来重新构建组建 StatefulWidget的Wdiget是通过State的Build方法构建的 setState方法将要重新构建的

1.8K10

flutter中对列表的性能优化

shrinkWrap强行评估整个内部列表,允许它请求有限的高度,而不是通常的ListView对象高度,即无穷大!...而且你滑动的快的时候列表会抖动! 重新构建嵌套列表 要了解如何使您的用户免受卡顿威胁,请等待我的第二节,下一节将使用 Slivers 而不是 ListViews 重建相同的 UI。...原始版本ListView对所有内容都使用对象,不知道内部构建器构造函数将被shrinkWrap. // Before @override void initState() { super.initState...运行应用程序并注意 Flutter 不再需要立即渲染 100 个 ColorRow 小部件。当您滚动时,会动态构建更多小部件,正如您所期望的那样。...更好的是,一直滚动到下一个列表也不会产生任何特殊费用。 Flutter 会根据需要重新构建小部件,而且很快。

4.8K00
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Flutter的生命周期

    组件发生变化时必须重新创建新的实例,而 StatefulWidget 组件则可以直接改变当前组件的状态而无需重新创建新的实例。...当 StatefulWidget 组件插入到组件树中时 「createState」 函数由 「Framework」 调用,此函数在树中给定的位置为此组件创建 「State」,如果在组件树的不同位置都插入了此组件...「State」,当组件从组件树中移除,然后重新插入到组件树中时, 「createState」 函数将会被调用创建一个新的 「State」。...生命周期二:initState 「initState」 函数在组件被插入树中时被 Framework 调用(在 「createState」 之后),此函数只会被调用一次,子类通常会重写此方法,在其中进行初始化操作...生命周期五:didUpdateWidget 当组件的 「configuration」 发生变化时调用此函数,当父组件使用相同的 「runtimeType」 和 「Widget.key」 重新构建一个新的组件时

    2.1K30

    Flutter--Flutter中Widget、App的生命周期

    在 Flutter 中一切皆 组件,而组件又分为 StatefulWidget(有状态) 和 StatelessWidget(无状态)组件 ,他们之间的区别是 StatelessWidget 组件发生变化时必须重新创建新的实例...,而 StatefulWidget 组件则可以直接改变当前组件的状态而无需重新创建新的实例。...当 StatefulWidget 组件插入到组件树中时 createState 函数由 Framework 调用,此函数在树中给定的位置为此组件创建 State,如果在组件树的不同位置都插入了此组件,即创建了多个此组件...State,当组件从组件树中移除,然后重新插入到组件树中时, createState 函数将会被调用创建一个新的 State。...1.2.5 生命周期五:didUpdateWidget 当组件的 configuration 发生变化时调用此函数,当父组件使用相同的 runtimeType 和 Widget.key 重新构建一个新的组件时

    4.9K31

    Stateful 组件的生命周期​

    在 Flutter 中一切皆 组件,而组件又分为 StatefulWidget(有状态) 和 **StatelessWidget(无状态)**组件 ,他们之间的区别是 StatelessWidget 组件发生变化时必须重新创建新的实例...,而 StatefulWidget 组件则可以直接改变当前组件的状态而无需重新创建新的实例。...当 StatefulWidget 组件插入到组件树中时 createState 函数由 Framework 调用,此函数在树中给定的位置为此组件创建 State,如果在组件树的不同位置都插入了此组件,即创建了多个此组件...State,当组件从组件树中移除,然后重新插入到组件树中时, createState 函数将会被调用创建一个新的 State。...生命周期五:didUpdateWidget 当组件的 configuration 发生变化时调用此函数,当父组件使用相同的 runtimeType 和 Widget.key 重新构建一个新的组件时,Framework

    1.3K10

    围观Github上Flutter评论最多的Issue

    在State内部实例化MyRequest, 在initState和dispose内分别做初始化和清理释放。 要复用的话就需要把上面做的事情在其他Widget那里重复。...当userId变化的时候重新做请求 @override void didUpdateWidget(Example oldWidget) { super.didUpdateWidget(oldWidget...如果要添加/删除一个MyRequest就需要至少在initState,didUpdateWidget和dispose等函数中做操作。...首先,就是“模块”应该是包含有一块独立的状态逻辑。比如上面说的一个网络请求,一次IO操作等等。“模块”应该是与UI无关的,所以“模块”内部最好不依赖于外部的Widget。...没有initState,didUpdateWidget和dispose等生命周期回调,没有Builder那样的嵌套,没有零碎的复制粘贴,甚至连StatefulWidget也都不再需要了。

    1.2K10

    【Flutter】Flutter 页面生命周期 ( 初始化期 | createState | initState | 更新期 | build | 销毁期 | dispose)

    文章目录 一、Flutter 页面生命周期 1、StatelessWidget 组件生命周期函数 2、StatefulWidget 组件生命周期函数 二、StatefulWidget 组件生命周期...组件生命周期函数 StatefulWidget 组件生命周期分为三组 : ① 初始化期 : createState , initState ; ② 更新期 : didChangeDependencies...createState 函数 : 所处时期 : 初始化期的生命周期函数 调用时机 : 创建 StatefulWidget 之后调用的第一个方法 ; 抽象方法 : 该方法是抽象方法 , 必须覆盖重写该方法...createState() => _WidgetLiftCyclePageState(); 2、initState initState 函数 : 所处时期 : 初始化期的生命周期函数 调用时机 : 该方法是创建...(); print("dispose"); } } 运行效果 : 打印日志 : 进入界面 , 点击 3 下按钮 , 然后退出界面 ; 进入界面 : 先调用 initState 方法

    5.6K00

    Flutter性能调优、复杂业务保证Flutter的高性能高流畅

    从这里可以看出,Flutter的平台相关层很低,平台(如iOS)只是提供一个画布,剩余的所有渲染相关的逻辑都在Flutter内部,这就使得它具有了很好的跨端一致性。...Widget是不可改变,需要重新创建一颗新树,build开始,然后对上一帧的element树做遍历,调用他的updateChild,看子节点类型跟之前是不是一样,不一样的话就把子节点扔掉,创造一个新的,...重新layout、paint,再生成新的layer交给GPU,流程如下图: ?...结合第一部分渲染原理我们了解到,每次定时器刷新text数字的时候,整个页面widget树都会重新build,但其实只有最底层Container中的Text内容在改变,没有必要刷新整颗树,所以这里我们的优化方案是提高...build效率,降低Widget tree遍历的出发点,将setState刷新数据尽量下发到底层节点,所以将Text单独抽取成独立的Widget,setState下发到抽取出的Widget内部 import

    1.7K31

    如何快速提升 Flutter App 中的动画性能

    涉及到动画,有状态,用 StatefulWidget ,State 里创建一个 AnimationController,用两个 Container 对应两个圈,外圈的 Container 的宽高监听动画跟着更新就行...代码如下: const double size = 56; class BubbleAnimationByAnimationController extends StatefulWidget { @...可以发现,在 Build 阶段,BubbleAnimationByAnimationController 因为 setState 引发 rebuild,进而重新 build 了两个 Container,...解决办法也很简单,把内圈的 Widget 提前构建好,外圈直接用就行了: class BubbleAnimationByAnimationController extends StatefulWidget...可以看到,整个 APP 界面包括头部的 AppBar 的颜色是跟着内部的汽泡一起变的,说明在随着内部动画而发生 repaint。

    2K20

    MCM数控机床切削颤振监测与大数据分析系统构建(一)

    因此,颤振成为提高机床加工能力的最主要障碍。 依照切削颤振的物理形成原因来划分基本上有3大类: 第1类是振型耦合型颤振; 第 2类是摩擦型颤振; 第 3类是再生型颤振。...振型耦合型颤振是指由于振动系统在 2个方向 上的刚度相近,导致 2个固有振型相接近时而引起 的颤振。摩擦型颤振是指在切削速度方向上刀具与工件之间的相互摩擦所引起的颤振。...再生型颤振是指由于上次切削所形成的振纹与本次切削的振动位移之间的相位差导致刀具的切削厚度的不同而引起的颤振。...基于WebAccess/MCM的数控机床切削颤振在线监测系统如下: 根据切削颤振的故障模型,当机床发生颤振时,振动信号在时域上幅值增大、在频域上主频带由高频带向低频带移动。...建立私有云,将积累的机床运行数据运用数据挖掘工具进行回归分析、聚类、关联规则、神经网络学习等,大数据分析是工业专家预测系统的加持,经过数据关联分析,发现新的故障模型和运行优化方案。

    3.8K40

    提到生命周期,我们是在说什么?

    如果我们的根布局是一个StatefulWidget,那么在其State中每调用一次setState更新UI,都将是一整个页面所有Widget的销毁和重建。...因此StatefulWidget并不是万金油,我们在实际开发中,要正确审视自己的视图展示需求,避免无谓的StatefulWidget使用,这是提高页面渲染效率最简单也最直接的手段。...而StatefulWidget,还需要借助其State对象,在特定阶段来处理用户的交互或其内部数据的变化,并体现在UI上。这些特定的阶段,就涵盖了一个组件从加载到卸载的全过程,即生命周期。...我们可以通过初始化方法,接收父Widget传递过来的初始化UI配置参数,这些配置参数决定了Widget的最初配置效果 initState,会在State对象被插入视图树的时候调用,这个函数在State的生命周期中只会被调用一次...值得注意的是,页面切换时,由于State对象在视图树中的位置发生了变化,需要暂时移除后再重新添加,重新触发组件构建,因此这个函数也会被调用。

    2K10

    widget简介

    当 widget 的状态改变时,它会重新构建其描述(展示的 UI),框架则会对比前后变化的不同,以确定底层渲染树从一个状态转换到下一个状态所需的最小更改。..., textDirection: TextDirection.ltr, ), ), ); } runApp() 函数会持有传入的 Widget,并且使它成为 widget...•canUpdate(...)是一个静态方法,它主要用于在Widget树重新build时复用旧的widget,其实具体来说,应该是:是否用新的Widget对象去更新旧UI树上所对应的Element对象的配置...有关Key和Widget复用的细节将会在本书后面高级部分深入讨论,读者现在只需知道,为Widget显式添加key的话可能(但不一定)会使UI在重新构建时变的高效,读者目前可以先忽略此参数。...() { ///初始化,这个函数在生命周期中只调用一次 super.initState(); ///定时1秒 new Future.delayed(const Duration

    1.8K20
    领券