首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

flutter源码:setState分析

setState方法算是flutter使用最频繁的方法了,每次页面数据有改变,都需要调用这个方法,去触发页面的刷新,展示最新的UI效果,接下来从源码角度解读下setState后具体发生了什么 系统源码部分...,会做截取,仅保留跟主题有关的部分,开始吧 void setState(VoidCallback fn) { // 省略了一大堆的判断代码 final Object?...scheduleBuildFor(this); } 就是把这个element标记为dirty,如果已经标记过,则忽略,说明连续调用两次setState方法,第二次其实是多余的,然后是调用owner...其实就是告诉系统,在下一帧刷新的时候,需要更新当前widget,整个过程,是一个异步的行为,所以下面的三个写法,效果上是一样的 // 写法一 _counter++; setState((...) {}); // 写法二 setState(() { _counter++; }); // 写法三 setState(() {}); _counter+

42010

Flutter | 启动,渲染,setState 流程

下面我们以 setState 的更新流程为例先对整个更新流程有一个比较深的印象。 setState 执行流 void setState(VoidCallback fn) { assert(fn !...这也侧面说明如果你频繁的 setState 的时候,如果上次的渲染流程没有完成,则不会发起新的渲染。...注释2:flutter framework 想 Flutter Engine 发起一个请求,接着 Flutter 引擎会在合适的时机去调用 onBeginFrame 和 onDrawFrame。...到此,setState 中最核心的就是触发了一个 请求,在下一次屏幕刷新的时候就会回调 onBeginFrame,执行完成之后才会调用 onDrawFrame 方法。...上屏,会将绘制出的bit数据发送给GPU .....///// } } 复制代码 以上,便是 setState 调用的大概过程,实际的流程会更加复杂一点,例如在这个过程中不允许再次调用 setState

1.1K10
您找到你想要的搜索结果了吗?
是的
没有找到

告别setState()! 优雅的UI与Model绑定 Flutter DataBus使用~

Flutter开发中,大家都绕不开Widget的刷新,setState()是最简单的用法。...但随着当app的交互变得复杂,setState出现的次数便会显著增加,每次setState都会重新调用build方法,这势必对于性能以及代码的可阅读性带来一定的影响。...如何优雅的解决这个问题,不得不提到StreamBuilder,StreamBuilder是Flutter中异步构建的核心组件。许多著名的开源框架例如Bloc皆是基于此实现。...img 采用setState()的方式,我们知道很简单,建立本地变量key1,key2,然后放入对应的Text中直接展示。...其实Flutter中还提供了一个强大组件SteamBuilder来协助我们处理控件的刷新构建。 ---- StreamBuilder ? ?

2.4K41

FluttersetState更新原理和流程

分析 Flutter状态类: StatelessWidget:无状态类,没有状态更新,界面一经创建无法更改; StatefulWidget:有状态类,当状态改变,调用setState()方法会触发StatefulWidget...也就是只有当我们的类是有状态类的时候才能进行状态刷新,setState也是在State(有状态类)类里 解析 :framework.dart文件State类 调用 setState() 必须是没有调用过...if (mounted) { setState(() {}); } setState方法 void setState(VoidCallback fn) { ......_element.markNeedsBuild(); } setState方法除了一些条件判断就是:_element.markNeedsBuild();那我们看看markNeedsBuild。...() { client_.ScheduleFrame(); // 看下面Engine::ScheduleFrame } Engine::ScheduleFrame 所在文件:flutter/shell

72520

Flutter 的状态管理方案:setState、BLoC、ValueNotifier、Provider

ValueNotifier,什么时候用 ChangeNotifier 呢?...在构建自己的应用程序时,你可以根据具体情况来评估哪个方案更合适 小彩蛋:实现 Drawer 菜单 跟踪当前选择的选项也是一个状态管理问题: 我首先在自定义 Drawer 菜单中使用本地状态变量和 setState...使用 Provider,我们可以选择在哪里存储 widget 树中的状态。 这样,即使删除使用它的小部件,状态也会被保留。 ValueNotifier 比 setState 需要更多的代码。...Flutter & Firebase Udemy 课程中有深入介绍。...这可以通过此链接进行了解(点这个链接有折扣哦): Flutter & Firebase: Build a Complete App for iOS & Android 祝你代码敲得开心!

4.4K00

什么时候使用Dockerfiles(什么时候使用……)

在这篇文章中,我们将讨论一些使用 Dockerfile 的最佳实践,探索一些注意事项,并使用 Dockerfile 和云原生 Buildpacks 构建应用。...你将了解每种工具最擅长的工作是什么,以及如何决定何时使用它们。 Dockerfiles 是什么? Dockerfile 是一个包含命令的文本文件,Docker 将执行这些命令来构建一个容器镜像。...编写更好的 Dockerfile 我们开始使用 golang:1.16.5 作为我们的 Go 应用程序的基本镜像。...使用 scratch 镜像也节省了大量空间,因为我们实际上不需要 Go 工具或其他工具来运行编译后的程序。使用一个容器用于构建,另一个容器用于最终镜像,这称为多阶段构建。...pack 使用构建包来帮助你轻松创建可以在任何地方运行的 OCI 镜像。

1.7K20

【- Flutter 性能 -】都 2021 年了,你的动画还在用 setState

Flutter 为我们提供了 AnimatedBuilder。 ? ? ---- 3....这不是啪啪啪打我 setState 的脸吗? ? 从下面的 UI 帧中 可以看出,同样的情景,使用 AnimatedBuilder 进行动画可以很有效地使 Build 过程缩短。 ? ?...更新还是要靠 setState。但比起上面的那个setState ,这里的 setState 的影响就小很多。...---- 这样来看,AnimatedBuilder 似乎也没有什么神秘的,了解了这些,再去看 Flutter 框架中的封装的各种动画组件,你就会豁然开朗,这便是知一而通百。...总结一下,并不是说 setState 不好,而是用的时机对不对。AnimatedBuilder 本质上也是使用 setState 进行触发更新的,所以看待问题不要片面和激进。

94520

什么时候使用Excel?

什么情景下,我会选用Excel而不使用PowerBI。 1.非数据分析需求 作为世界上最流行的电子表格工具,Excel的很多应用可以是非数据分析需求。...如果仅是一张简单的销售数据表,而且你的需求只是一次性地分析销售总量,快速地生成一个普通的数据透视表就可以达到目标,我们没有必要使用PowerBI。 ?...5.编辑查询器 PowerBI是从Excel的BI插件衍生而来的,我们说使用PowerBI操作流畅性、稳定性、功能性都更胜一筹,这主要是针对PowerPivot建模和可视化两个模块来讲。...在没有体验差别的情况下,直接使用Excel无需切换不同的软件来操作。另外,Excel的编辑查询器操作完后可以很方便地生成一张查询后的Excel表输出,这往往也是数据清洗工作后需要的结果。 ?

1.9K20

Flutter进阶-Key之GlobalKey

Flutter世界中,Key分为两种类型,一种是GlobalKey,一种LocalKey,LocalKey具体到实现的类型又有ObjectKey, UniqueKey,ValueKey等等… 本文我们将讨论的是...那它是什么时候被注册进去的呢?我们接着看。...= newWidget.createElement();‘‘ ,接着调用newChild.mount(this, newSlot);在Element的mount方法中,我们看到了对GlobalKey的使用...实现原理: 在开始探索原理之前,我们需要明白setState的流程,我们简单过一下,在setState之后,会将当前widget(MyHomePage)markNeedsBuild,markNeedsBuild...答案是会的,但是build方法调用不代表我们的widget被重新绘制,在Flutter中build方法是生成widget配置信息的,是很轻量也是会被频繁调用。

1.6K20

究竟什么时候使用MQ?

MQ,互联网技术体系中一个常见组件,究竟什么时候使用MQ,究竟什么时候使用MQ,MQ究竟适合什么场景,是今天要分享的内容。 MQ是什么?...什么时候使用MQ? 当调用方需要关心消息执行结果时,通常不使用MQ,而使用RPC调用。 ?...画外音:绝大部分情况,应该使用RPC。 此时如果强行使用MQ呢? ? 如果强行使用MQ通讯,调用方不能直接告之用户登录成功又或失败,则要等待另一个MQ通知回调。...究竟什么时候使用MQ呢? 下面四类典型场景,应该使用MQ。 典型场景一:数据驱动的任务依赖 什么是任务依赖?...什么时候使用MQ? 上游实时关注执行结果,通常采用RPC。 什么时候使用MQ? (1)数据驱动的任务依赖; (2)上游不关心多下游执行结果; (3)异步返回执行时间长;

59521

到底什么时候使用MQ?

最近分享了几篇MQ相关的文章: 《MQ如何实现延时消息》 《MQ如何实现消息必达》 《MQ如何实现幂等性》 不少网友询问,究竟什么时候使用MQ,MQ究竟适合什么场景,故有了此文。...使用了MQ之后,消息发送上游只需要依赖MQ,逻辑上和物理上都不用依赖其他服务。 三、什么时候使用消息总线 ? 既然MQ是互联网分层架构中的解耦利器,那所有通讯都使用MQ岂不是很好?...,而不能使用MQ通信。...四、什么时候使用MQ 【典型场景一:数据驱动的任务依赖】 什么是任务依赖,举个栗子,互联网公司经常在凌晨进行一些数据统计任务,这些任务之间有一定的依赖关系,比如: 1)task3需要使用task2的输出作为输入...什么时候使用MQ? 上游实时关注执行结果 什么时候使用MQ? 1)数据驱动的任务依赖 2)上游不关心多下游执行结果 3)异步返回执行时间长

2.3K50

Flutter 实战】一文学会20多个动画组件

老孟导读:此篇文章是 Flutter 动画系列文章第三篇,后续还有动画序列、过度动画、转场动画、自定义动画等。...Flutter 系统提供了20多个动画组件,只要你把前面【动画核心】(文末有链接)的文章看明白了,这些组件对你来说是非常轻松的,这些组件大部分都是对常用操作的封装。...系统封装的类似上面的组件是 AnimatedWidget,此类是抽象类,源代码: 区别: 我们使用 监听 AnimationController,调用 setState ,而系统使用 Listenable...如何选取 Flutter 内置的动画组件分为两种:隐式动画组件 和 显示动画组件 ,显示动画组件只封装了 setState 方法,需要开发者创建 AnimationController,并管理 AnimationController...隐式动画组件可以完成效果,显示动画组件都可以完成,那么什么时候使用隐式动画组件?什么时候使用显示动画组件? 判断你的动画组件是否一直重复,比如一直转圈的loading动画,如果是选择显式动画。

67220
领券